# User Manual

for S32K1\_S32M24x MCU Driver

Document Number: UM2MCUASRR21-11 Rev0000R2.0.0 Rev. 1.0

| 1 | Revision History                                    | 2  |
|---|-----------------------------------------------------|----|
| 2 | Introduction                                        | 3  |
|   | 2.1 Supported Derivatives                           | 3  |
|   | 2.2 Overview                                        | 4  |
|   | 2.3 About This Manual                               | 5  |
|   | 2.4 Acronyms and Definitions                        | 6  |
|   | 2.5 Reference List                                  | 6  |
| 3 | Driver                                              | 7  |
|   | 3.1 Requirements                                    | 7  |
|   | 3.2 Driver Design Summary                           | 7  |
|   | 3.3 Hardware Resources                              | 8  |
|   | 3.4 Deviations from Requirements                    | 8  |
|   | 3.4.1 Status Column Description                     | 8  |
|   | 3.4.2 Mcu Requirements Deviations                   | 8  |
|   | 3.5 Driver Limitations                              | 9  |
|   | 3.6 Driver usage and configuration tips             | 10 |
|   | 3.6.1 MCU Clock Management                          | 10 |
|   | 3.6.2 Specific clock use case:                      | 11 |
|   | 3.6.3 MCU Mode Management                           | 11 |
|   | 3.6.4 MCU RAM Configuration                         | 11 |
|   | 3.7 Runtime errors                                  | 11 |
|   | 3.8 Symbolic Names Disclaimer                       | 12 |
| 4 | Tresos Configuration Plug-in                        | 13 |
|   | 4.1 Module Mcu                                      | 19 |
|   | 4.2 Container McuGeneralConfiguration               | 19 |
|   | 4.3 Parameter McuDevErrorDetect                     | 19 |
|   | 4.4 Parameter McuVersionInfoApi                     | 20 |
|   | 4.5 Parameter McuGetRamStateApi                     | 20 |
|   | 4.6 Parameter McuInitClock                          | 22 |
|   | 4.7 Parameter McuNoPll                              | 22 |
|   | 4.8 Parameter McuEnterLowPowerMode                  | 23 |
|   | 4.9 Parameter McuTimeout                            | 23 |
|   | 4.10 Parameter McuEnableUserModeSupport             | 24 |
|   | 4.11 Parameter McuPerformResetApi                   | 25 |
|   | 4.12 Parameter McuCalloutBeforePerformReset         | 25 |
|   | 4.13 Parameter McuVeryLowPowerStopAbortNotification | 26 |
|   | 4.14 Parameter McuPerformResetCallout               |    |
|   | 4.15 Parameter McuCmuNotification                   | 27 |
|   |                                                     |    |

| 4.16 Parameter McuCmuErrorIsrUsed              | <br>. 27 |
|------------------------------------------------|----------|
| 4.17 Parameter McuErrorIsrNotification         | <br>. 28 |
| 4.18 Parameter McuDisableRcmInit               | <br>. 28 |
| 4.19 Parameter McuDisablePmcInit               |          |
| 4.20 Parameter McuDisableSmcInit               | <br>. 29 |
| 4.21 Parameter McuEnableModeChangeNotification | <br>. 30 |
| 4.22 Parameter McuTimeoutMethod                |          |
| 4.23 Parameter McuRegisterValuesOptimization   |          |
| 4.24 Reference McuEcucPartitionRef             |          |
| 4.25 Container McuDebugConfiguration           |          |
| 4.26 Parameter McuDisableDemReportErrorStatus  |          |
| 4.27 Parameter McuGetMidrStructureApi          |          |
| 4.28 Parameter McuDisableCmuApi                |          |
| 4.29 Parameter McuEnablePeripheralCMU          |          |
| 4.30 Parameter McuSRAMRetentionConfigApi       |          |
| 4.31 Parameter McuGetClockFrequencyApi         |          |
| 4.32 Parameter McuGetPowerModeStatetApi        |          |
| 4.33 Parameter McuPmcAeConfigApi               |          |
| 4.34 Parameter McuAecResetConfigApi            |          |
| 4.35 Container McuPublishedInformation         |          |
| 4.36 Container McuResetReasonConf              |          |
| 4.37 Parameter McuResetReason                  |          |
| 4.38 Container CommonPublishedInformation      |          |
| 4.39 Parameter ArReleaseMajorVersion           |          |
| 4.40 Parameter ArReleaseMinorVersion           |          |
| 4.41 Parameter ArReleaseRevisionVersion        | . 40     |
| 4.42 Parameter ModuleId                        | . 41     |
| 4.43 Parameter SwMajorVersion                  |          |
| 4.44 Parameter SwMinorVersion                  |          |
| 4.45 Parameter SwPatchVersion                  |          |
| 4.46 Parameter VendorApiInfix                  |          |
| 4.47 Parameter VendorId                        |          |
| 4.48 Container McuModuleConfiguration          |          |
| 4.49 Parameter McuNumberOfMcuModes             |          |
| 4.50 Parameter McuRamSectors                   |          |
| 4.51 Parameter McuResetSetting                 |          |
| 4.52 Parameter McuRTC_CLKINFrequencyHz         |          |
| 4.53 Parameter McuTCLK0_REF_CLKFrequencyHz     |          |
| 4.54 Parameter McuTCLK1_REF_CLKFrequencyHz     |          |
| 4.55 Parameter McuTCLK2 REF CLKFrequencyHz     | <br>. 48 |

| 4.56 P | Parameter | r McuClockSrcFailureNotification | . 48 |
|--------|-----------|----------------------------------|------|
| 4.57 C | Container | McuAllowedModes                  | . 49 |
| 4.58 P | arameter  | r McuAllowHighSpeedRunMode       | . 49 |
| 4.59 P | arameter  | r McuAllowVeryLowPowerModes      | . 50 |
| 4.60 C | Container | McuClockSettingConfig            | . 50 |
| 4.61 P | arameter  | r McuClockSettingId              | . 51 |
| 4.62 P | arameter  | r McuSysClockUnderMcuControl     | . 52 |
| 4.63 P | arameter  | r McuScgClkOutSelect             | . 52 |
| 4.64 C | Container | McuRunClockConfig                | . 53 |
| 4.65 P | arameter  | r McuPreDivSystemClockFrequency  | . 53 |
| 4.66 P | arameter  | r McuCoreClockFrequency          | . 54 |
| 4.67 P | arameter  | r McuSystemClockFrequency        | . 55 |
| 4.68 P | arameter  | r McuBusClockFrequency           | . 55 |
| 4.69 P | arameter  | r McuFlashClockFrequency         | . 56 |
| 4.70 P | arameter  | r McuSystemClockSwitch           | . 56 |
| 4.71 P | arameter  | r McuCoreClockDivider            | . 57 |
| 4.72 P | arameter  | r McuBusClockDivider             | . 58 |
| 4.73 P | arameter  | r McuSlowClockDivider            | . 58 |
| 4.74 P | arameter  | r McuScgClkOutFrequency          | . 59 |
| 4.75 C | Container | McuVlprClockConfig               | . 59 |
| 4.76 P | arameter  | r McuPreDivSystemClockFrequency  | . 60 |
| 4.77 P | arameter  | r McuCoreClockFrequency          | . 61 |
| 4.78 P | arameter  | r McuSystemClockFrequency        | . 61 |
| 4.79 P | arameter  | r McuBusClockFrequency           | . 62 |
| 4.80 P | arameter  | r McuFlashClockFrequency         | . 62 |
| 4.81 P | arameter  | r McuSystemClockSwitch           | . 63 |
| 4.82 P | arameter  | r McuCoreClockDivider            | . 64 |
| 4.83 P | arameter  | r McuBusClockDivider             | . 64 |
| 4.84 P | arameter  | r McuSlowClockDivider            | . 65 |
| 4.85 P | arameter  | r McuScgClkOutFrequency          | . 65 |
| 4.86 C | Container | McuHsrunClockConfig              | . 66 |
| 4.87 P | arameter  | r McuPreDivSystemClockFrequency  | . 66 |
| 4.88 P | arameter  | r McuCoreClockFrequency          | . 67 |
| 4.89 P | arameter  | r McuSystemClockFrequency        | . 67 |
| 4.90 P | arameter  | r McuBusClockFrequency           | . 68 |
| 4.91 P | arameter  | r McuFlashClockFrequency         | . 69 |
| 4.92 P | arameter  | r McuSystemClockSwitch           | . 69 |
| 4.93 P | arameter  | r McuCoreClockDivider            | . 70 |
| 4.94 P | arameter  | r McuBusClockDivider             | . 70 |
| 4.95 P | arameter  | r McuSlowClockDivider            | . 71 |

| 4.96 Parameter McuScgClkOutFrequency            | . 72 |
|-------------------------------------------------|------|
| 4.97 Container McuSystemOSCClockConfig          | . 72 |
| 4.98 Parameter McuSOSCUnderMcuControl           | . 72 |
| 4.99 Parameter McuSOSCFrequency                 | . 73 |
| 4.100 Parameter McuSOSCDiv2Frequency            | . 74 |
| 4.101 Parameter McuSOSCDiv1Frequency            | . 74 |
| 4.102 Parameter McuSOSCEnable                   |      |
| 4.103 Parameter McuSOSCClockMonitorResetEnable  | . 75 |
| 4.104 Parameter McuSOSCClockMonitorEnable       |      |
| 4.105 Parameter McuSOSCDiv2                     |      |
| 4.106 Parameter McuSOSCDiv1                     |      |
| 4.107 Parameter McuSOSCRangeSelect              | . 78 |
| 4.108 Parameter McuSOSCHighGainOscillatorSelect |      |
| 4.109 Parameter McuSOSCExternalReferenceSelect  |      |
| 4.110 Container McuSIRCClockConfig              |      |
| 4.111 Parameter McuSIRCUnderMcuControl          | . 80 |
| 4.112 Parameter McuSIRCFrequency                | . 81 |
| 4.113 Parameter McuSIRCDiv2Frequency            | . 81 |
| 4.114 Parameter McuSIRCDiv1Frequency            | . 82 |
| 4.115 Parameter McuSIRCEnable                   |      |
| 4.116 Parameter McuSIRCLowPowerEnable           | . 84 |
| 4.117 Parameter McuSIRCStopEnable               | . 84 |
| 4.118 Parameter McuSIRCDiv2                     | . 85 |
| 4.119 Parameter McuSIRCDiv1                     | . 86 |
| 4.120 Parameter McuSIRCRangeSelect              | . 86 |
| 4.121 Container McuFIRCClockConfig              | . 87 |
| 4.122 Parameter McuFIRCUnderMcuControl          | . 87 |
| 4.123 Parameter McuFIRCFrequency                | . 88 |
| 4.124 Parameter McuFIRCDiv2Frequency            | . 88 |
| 4.125 Parameter McuFIRCDiv1Frequency            | . 89 |
| 4.126 Parameter McuFIRCEnable                   | . 90 |
| 4.127 Parameter McuFIRCRegulatorEnable          | . 90 |
| 4.128 Parameter McuFIRCDiv2                     | . 91 |
| 4.129 Parameter McuFIRCDiv1                     | . 91 |
| 4.130 Parameter McuFIRCRangeSelect              | . 92 |
| 4.131 Container McuSystemPll                    | . 93 |
| 4.132 Parameter McuSystemPllUnderMcuControl     | . 93 |
| 4.133 Parameter McuSPLLFrequency                | . 94 |
| 4.134 Parameter McuSPLLDiv2Frequency            | . 94 |
| 4.135 Parameter McuSPLLDiv1Frequency            | . 95 |

| 4.136 Parameter McuSPLLEnable                                                                                                                                                                                                     |     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 4.137 Parameter McuSPLLClockMonitorResetEnable                                                                                                                                                                                    |     |
|                                                                                                                                                                                                                                   | 96  |
|                                                                                                                                                                                                                                   | 97  |
| 4.140 Parameter McuSPLLDiv1                                                                                                                                                                                                       |     |
| 4.141 Parameter McuSPLLInputClkPreDivider                                                                                                                                                                                         |     |
| 4.142 Parameter McuSPLLReferenceFrequency                                                                                                                                                                                         |     |
| 4.143 Parameter McuSPLLInputFrequency                                                                                                                                                                                             | 99  |
| 4.144 Parameter McuSPLLMultiplier                                                                                                                                                                                                 |     |
| 4.145 Parameter McuSPLLSelectSourceClock                                                                                                                                                                                          | 101 |
| $4.146\ Container\ McuSIMClockConfig\ .$                                                                                                                                                                                          | 101 |
| $4.147 \ Parameter \ McuSIMUnderMcuControl \ . \ . \ . \ . \ . \ . \ . \ . \ . \ $                                                                                                                                                | 102 |
| $4.148\ Parameter\ McuEIMClockGatingEnable\ \dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots\dots$ | 102 |
| $4.149\ Parameter\ McuERMClockGatingEnable\ .\ .\ .\ .\ .\ .$                                                                                                                                                                     | 103 |
| $4.150 \; Parameter \; McuDMAClockGatingEnable \; \ldots \; $                                                                                     | 103 |
| $4.151\ Parameter\ McuMPUClockGatingEnable \dots \dots$                                                                     | 104 |
| $4.152\ Parameter\ McuMSCMClockGatingEnable \dots \dots$                                                                    | 104 |
| 4.153 Parameter McuGPIOClockGatingEnable                                                                                                                                                                                          | 105 |
| 4.154 Container McuSimChipConfiguration                                                                                                                                                                                           | 105 |
| $4.155 \ Parameter \ McuDebugTraceDividerEnable \ . \ . \ . \ . \ . \ . \ . \ . \ . \ $                                                                                                                                           | 106 |
| 4.156 Parameter McuTRACECLKDivider                                                                                                                                                                                                | 106 |
| 4.157 Parameter McuTRACECLKFraction                                                                                                                                                                                               | 107 |
| 4.158 Parameter McuTRACECLKSelect                                                                                                                                                                                                 | 108 |
| 4.159 Parameter McuCLKOUTEnable                                                                                                                                                                                                   | 108 |
| 4.160 Parameter McuCLKOUTDivider                                                                                                                                                                                                  | 109 |
| 4.161 Parameter McuCLKOUTSelect                                                                                                                                                                                                   | 109 |
| 4.162 Container McuSimLpoConfiguration                                                                                                                                                                                            | 110 |
| 4.163 Parameter McuRTCClkSelect                                                                                                                                                                                                   | 111 |
| 4.164 Parameter McuLPOClkSelect                                                                                                                                                                                                   | 111 |
| 4.165 Parameter McuLPO_32KClockEnable                                                                                                                                                                                             | 112 |
| 4.166 Parameter McuLPO_1KClockEnable                                                                                                                                                                                              | 112 |
| 4.167 Container McuSimFtmConfiguration                                                                                                                                                                                            | 113 |
| 4.168 Parameter McuFTM3ExternalClockPinSelect                                                                                                                                                                                     | 113 |
| 4.169 Parameter McuFTM2ExternalClockPinSelect                                                                                                                                                                                     | 114 |
| 4.170 Parameter McuFTM1ExternalClockPinSelect                                                                                                                                                                                     | 115 |
| 4.171 Parameter McuFTM0ExternalClockPinSelect                                                                                                                                                                                     | 116 |
| 4.172 Parameter McuFTM7ExternalClockPinSelect                                                                                                                                                                                     | 116 |
| 4.173 Parameter McuFTM6ExternalClockPinSelect                                                                                                                                                                                     | 117 |
| 4.174 Parameter McuFTM5ExternalClockPinSelect                                                                                                                                                                                     | 118 |
| 4.175 Parameter McuFTM4ExternalClockPinSelect                                                                                                                                                                                     | 118 |

| 4.176 Container McuClkMonitor                     |
|---------------------------------------------------|
| 4.177 Container McuClkMonitor_0                   |
| 4.178 Parameter McuClockMonitorUnderMcuControl    |
| 4.179 Parameter McuClkMonitorEn                   |
| 4.180 Parameter McuCmuName                        |
| 4.181 Parameter McuAsyncFHHInterruptEn            |
| 4.182 Parameter McuAsyncFLLInterruptEn            |
| 4.183 Container McuClkMonitor_1                   |
| 4.184 Parameter McuClockMonitorUnderMcuControl    |
| 4.185 Parameter McuClkMonitorEn                   |
| 4.186 Parameter McuCmuName                        |
| 4.187 Parameter McuSyncFHHInterruptEn             |
| 4.188 Parameter McuSyncFLLInterruptEn             |
| 4.189 Container McuPeripheralClockConfig          |
| 4.190 Parameter McuPeripheralClockUnderMcuControl |
| 4.191 Parameter McuPerName                        |
| 4.192 Parameter McuPeripheralClockEnable          |
| 4.193 Parameter McuPeripheralClockSelect          |
| 4.194 Parameter McuPeripheralClockDivider         |
| 4.195 Parameter McuPeripheralFractionalDivider    |
| 4.196 Parameter McuPeripheralClockFrequency       |
| 4.197 Container McuClockReferencePoint            |
| 4.198 Parameter McuClockReferencePointFrequency   |
| 4.199 Parameter McuClockFrequencySelect           |
| 4.200 Container McuDemEventParameterRefs          |
| 4.201 Reference MCU_E_TIMEOUT_FAILURE             |
| 4.202 Reference MCU_E_CLOCK_FAILURE               |
| 4.203 Reference MCU_E_SWITCHMODE_FAILURE          |
| 4.204 Container McuModeSettingConf                |
| 4.205 Parameter McuMode                           |
| 4.206 Parameter McuPowerMode                      |
| 4.207 Parameter McuEnableSleepOnExit              |
| 4.208 Container McuRamSectorSettingConf           |
| 4.209 Parameter McuRamSectorId                    |
| 4.210 Parameter McuRamDefaultValue                |
| 4.211 Parameter McuRamSectionBaseAddress          |
| 4.212 Parameter McuRamSectionSize                 |
| 4.213 Parameter McuRamSectionWriteSize            |
| 4.214 Parameter McuRamSectionBaseAddrLinkerSym    |
| 4.215 Parameter McuRamSectionSizeLinkerSym        |

| 4.216 Container McuInterruptEvents                       | 140 |
|----------------------------------------------------------|-----|
| 4.217 Parameter McuVoltageErrorEvent                     | 141 |
| 4.218 Parameter McuAlternateResetEvent                   | 141 |
| 4.219 Container McuResetConfig                           | 141 |
| 4.220 Parameter McuResetPinFilterBusClockSelect          | 142 |
| 4.221 Parameter McuResetPinFilterInStopMode              | 142 |
| 4.222 Parameter McuResetPinFilterInRunAndWait            | 143 |
| 4.223 Container McuSystemInterruptEnable                 | 144 |
| 4.224 Parameter McuResetDelayTime                        | 144 |
| 4.225 Parameter McuStopAcknowledgeErrorInterrupt         | 145 |
| 4.226 Parameter McuMDMAPSystemResetInterrupt             | 145 |
| 4.227 Parameter McuSoftwareInterrupt                     | 146 |
| 4.228 Parameter McuCoreLockupInterrupt                   | 147 |
| 4.229 Parameter McuJTAGResetInterrupt                    | 147 |
| 4.230 Parameter McuGlobalInterrupt                       | 148 |
| 4.231 Parameter McuExternalResetPinInterrupt             | 148 |
| 4.232 Parameter McuWatchdogInterrupt                     | 149 |
| 4.233 Parameter McuCMULossOfClockResetInterrupt          | 149 |
| 4.234 Parameter McuLossOfLockInterrupt                   | 150 |
| 4.235 Parameter McuLossOfClockInterrupt                  | 150 |
| 4.236 Container McuResetGeneratorConfiguration           | 151 |
| 4.237 Parameter McuRegsOtpReset                          | 151 |
| 4.238 Parameter McuCanPhyReset                           | 152 |
| 4.239 Parameter McuLinPhyHpReset                         | 152 |
| 4.240 Parameter McuLinPhyLpReset                         | 153 |
| 4.241 Parameter McuGduReset                              | 153 |
| 4.242 Parameter McuHviReset                              | 154 |
| 4.243 Parameter McuDpgaReset                             |     |
| 4.244 Parameter McuTempsensorReset                       | 155 |
| 4.245 Parameter McuCxpiReset                             | 156 |
| 4.246 Container McuPowerControl                          | 156 |
| 4.247 Container McuPMC_Config                            | 157 |
| 4.248 Parameter McuLowVoltageDetectInterruptEnable       |     |
| 4.249 Parameter McuLowVoltageDetectResetEnable           | 158 |
| 4.250 Parameter McuLowVoltageWarningInterruptEnable      |     |
| 4.251 Parameter McuLPODisable                            |     |
| 4.252 Parameter McuClockBiasDisable                      | 159 |
| 4.253 Parameter McuLowPowerBiasEnable                    | 160 |
| 4.254 Container McuPMC_AE_Config                         | 161 |
| 4.255 Parameter McuLowVoltageDetectInterruptsOnVLSEnable | 161 |

|   | 4.256 Parameter McuLowVoltageDetectInterruptsOnVDDCEnable                                          | . 162 |
|---|----------------------------------------------------------------------------------------------------|-------|
|   | $4.257\ Parameter\ McuHighVoltageDetectInterruptOnVDDEnable \$                                     | . 163 |
|   | $4.258\ Parameter\ McuHighVoltageDetectInterruptOnVDDINTAndVDD15Enable\ \dots\dots\dots\dots\dots$ | . 163 |
|   | 4.259 Parameter McuLinphySupplyEnable                                                              | . 164 |
|   | 4.260 Parameter McuVDDCEnable                                                                      | . 165 |
|   | 4.261 Parameter McuLvdVlsSelect                                                                    | . 165 |
|   | 4.262 Parameter McuLinphySupplySelect                                                              | . 166 |
|   | 4.263 Parameter McuVddVoltageLevelSelect                                                           | . 166 |
| 5 | Module Index                                                                                       | 168   |
|   | 5.1 Software Specification                                                                         | . 168 |
| 6 | Module Documentation                                                                               | 169   |
|   | 6.1 Clock Ip Driver                                                                                | . 169 |
|   | 6.1.1 Detailed Description                                                                         | . 169 |
|   | 6.1.2 Data Structure Documentation                                                                 | . 171 |
|   | 6.1.3 Types Reference                                                                              | . 178 |
|   | 6.1.4 Enum Reference                                                                               | . 178 |
|   | 6.1.5 Function Reference                                                                           | . 182 |
|   | 6.2 Mcu Driver                                                                                     | . 188 |
|   | 6.2.1 Detailed Description                                                                         | . 188 |
|   | 6.2.2 Data Structure Documentation                                                                 | . 189 |
|   | 6.2.3 Macro Definition Documentation                                                               | . 192 |
|   | 6.2.4 Types Reference                                                                              | . 192 |
|   | 6.2.5 Enum Reference                                                                               | . 193 |
|   | 6.2.6 Function Reference                                                                           | . 193 |
|   | 6.3 Power Ip Driver                                                                                | . 202 |
|   | 6.3.1 Detailed Description                                                                         | . 202 |
|   | 6.3.2 Data Structure Documentation                                                                 | . 203 |
|   | 6.3.3 Types Reference                                                                              | . 205 |
|   | 6.3.4 Enum Reference                                                                               | . 206 |
|   | 6.3.5 Function Reference                                                                           | . 208 |
|   | 6.4 Ram Ip Driver                                                                                  | . 212 |
|   | 6.4.1 Detailed Description                                                                         | . 212 |
|   | 6.4.2 Data Structure Documentation                                                                 | . 212 |
|   | 6.4.3 Types Reference                                                                              | . 213 |
|   | 6.4.4 Enum Reference                                                                               | . 214 |
|   | 6.4.5 Function Reference                                                                           | . 214 |

# **Chapter 1**

# **Revision History**

| Revision | Date       | Author       | Description                                          |
|----------|------------|--------------|------------------------------------------------------|
| 1.0      | 04.08.2023 | NXP RTD Team | S32K1_S32M24X Real-Time Drivers AUTOSAR 4.4 & R21-11 |
|          |            |              | Version 2.0.0                                        |

# **Chapter 2**

### Introduction

- Supported Derivatives
- Overview
- About This Manual
- Acronyms and Definitions
- Reference List

This User Manual describes NXP Semiconductors' AUTOSAR Mcu Driver for S32K1\_S32M24x.

AUTOSAR Mcu Driver configuration parameters description can be found in the Tresos Configuration Plugin section. Deviations from the specification are described in the Deviations from Requirements section.

AUTOSAR Mcu driver requirements and APIs are described in the Mcu Driver Software Specification Document (version R21-11).

# 2.1 Supported Derivatives

The software described in this document is intended to be used with the following microcontroller devices of NXP Semiconductors:

- s32k116\_qfn32
- s32k116\_lqfp48
- s32k118\_lqfp48
- $s32k118\_lqfp64$
- s32k142\_lqfp48
- s32k142\_lqfp64
- $s32k142\_lqfp100$
- $s32k142w_lqfp48$

#### Introduction

- s32k142w\_lqfp64
- s32k144\_lqfp48
- s32k144 lqfp64 / MWCT1014S lqfp64
- s32k144\_lqfp100 / MWCT1014S\_lqfp100
- s32k144\_mapbga100
- s32k144w\_lqfp48
- s32k144w lqfp64
- s32k146\_lqfp64
- s32k146 lqfp100 / MWCT1015S lqfp100
- s32k146\_mapbga100 / MWCT1015S\_mapbga100
- s32k146\_lqfp144
- s32k148\_lqfp100
- s32k148\_mapbga100 / MWCT1016S\_mapbga100
- s32k148\_lqfp144
- s32k148\_lqfp176
- $\bullet \hspace{0.1cm} s32m241\_lqfp64$
- s32m242\_lqfp64
- s32m243\_lqfp64
- s32m244\_lqfp64

All of the above microcontroller devices are collectively named as S32K1\_S32M24X. Note: MWCT part numbers contain NXP confidential IP for Qi Wireless Power

#### 2.2 Overview

AUTOSAR (AUTomotive Open System ARchitecture) is an industry partnership working to establish standards for software interfaces and software modules for automobile electronic control systems.

#### AUTOSAR:

- paves the way for innovative electronic systems that further improve performance, safety and environmental friendliness.
- is a strong global partnership that creates one common standard: "Cooperate on standards, compete on implementation".
- is a key enabling technology to manage the growing electrics/electronics complexity. It aims to be prepared for the upcoming technologies and to improve cost-efficiency without making any compromise with respect to quality.
- facilitates the exchange and update of software and hardware over the service life of the vehicle.

# 2.3 About This Manual

This Technical Reference employs the following typographical conventions:

- Boldface style: Used for important terms, notes and warnings.
- *Italic* style: Used for code snippets in the text. Note that C language modifiers such "const" or "volatile" are sometimes omitted to improve readability of the presented code.

Notes and warnings are shown as below:

Note

This is a note.

Warning

This is a warning

# 2.4 Acronyms and Definitions

| Term                                              | erm Definition                    |                           |
|---------------------------------------------------|-----------------------------------|---------------------------|
| API                                               | Application Programming Interface |                           |
| ASM                                               | Assembler                         |                           |
| BSMI Basic Software Make file Interface           |                                   |                           |
| CAN                                               | Controller Area Network           |                           |
| C/CPP                                             | C and C++ Source Code             |                           |
| CS                                                | Chip Select                       |                           |
| CTU                                               | Cross Trigger Unit                |                           |
| DEM                                               | Diagnostic Event Manager          |                           |
| DET                                               | Development Error Tracer          |                           |
| DMA                                               | Direct Memory Access              |                           |
| ECU                                               | Electronic Control Unit           |                           |
| FIFO First In First Out LSB Least Signifigant Bit |                                   |                           |
|                                                   |                                   | MCU Micro Controller Unit |
| MIDE Multi Integrated Development Environme       |                                   |                           |
| MSB Most Significant Bit                          |                                   |                           |
| N/A Not Applicable                                |                                   |                           |
| RAM Random Access Memory                          |                                   |                           |
| SIU Systems Integration Unit                      |                                   |                           |
| SWS Software Specification                        |                                   |                           |
| VLE                                               | Variable Length Encoding          |                           |
| XML Extensible Markup Language                    |                                   |                           |

# 2.5 Reference List

| #  | Title                       | Version                                              |
|----|-----------------------------|------------------------------------------------------|
| 1  | Specification of Mcu Driver | AUTOSAR Release R21-11                               |
| 2  | S32K1xx Reference Manual    | S32K1xx Series Reference Manual, Rev. 14, 09/2021    |
| 3  | S32K1xx Data Sheet          | S32K1xx Data Sheet, Rev. 14, 08/2021                 |
| 4  | S32M24x Reference Manual    | S32M24x Reference Manual, Rev. 2 Draft A, 05/2023    |
| 5  | S32M24x Data Sheet          | Supports S32M24x and S32M27x, Rev. 3 DraftA, 05/2023 |
| 6  | S32M244 Errata Document     | S32M244_P64A+P73G, Rev. 0                            |
| 6  | S32M242 Errata Document     | S32M242_N33V+P73G, Rev. 0, 6/2023                    |
| 7  | S32K116 Errata Document     | S32K116_0N96V Rev. 22/OCT/2021                       |
| 8  | S32K118 Errata Document     | S32K118_0N97V Rev. 22/OCT/2021                       |
| 9  | S32K142 Errata Document     | S32K142_0N33V Rev. 22/OCT/2021                       |
| 10 | S32K144 Errata Document     | S32K144_0N57U Rev. 22/OCT/2021                       |
| 11 | S32K144W Errata Document    | S32K144W_0P64A Rev. 22/OCT/2021                      |
| 12 | S32K146 Errata Document     | S32K146_0N73V Rev. 22/OCT/2021                       |
| 13 | S32K148 Errata Document     | S32K148_0N20V Rev. 22/OCT/2021                       |

# **Chapter 3**

### **Driver**

- Requirements
- Driver Design Summary
- Hardware Resources
- Deviations from Requirements
- Driver Limitations
- Driver usage and configuration tips
- Runtime errors
- Symbolic Names Disclaimer

# 3.1 Requirements

Requirements for this driver are detailed in the AUTOSAR R21-11 Mcu Driver Software Specification document (See Table Reference List)

# 3.2 Driver Design Summary

The Mcu Driver controls the CLOCK, POWER and RAM modules of the S32K1\_S32M24x device. It provides the following features:

- Configuration and initialization of the CLOCK.
- Configuration and initialization of the POWER.
- Configuration and initialization of the RAM.

Driver

#### 3.3 Hardware Resources

The Mcu Driver consists of:

- 1. Clock IPs (CMU,PCC,PRAMC,SIM,SCG)
- 2. Power IPs (PMC,RCM,SIM,SMC,AE\_PMC,AEC)
- 3. Ram IPs (PRAMC)

# 3.4 Deviations from Requirements

The driver deviates from the AUTOSAR Mcu Driver Software Specification in some places.

The table Mcu Requirements Deviations identifies the AUTOSAR requirements that are not fully implemented, implemented differently, or out of scope for the Mcu Driver.

The table Status Column Description provides the "Status" column description.

#### 3.4.1 Status Column Description

Table 3.1 Status Column Description Areas

| Term | Definition            |
|------|-----------------------|
| N/S  | Not In Scope          |
| N/I  | Not Implemented       |
| N/F  | Not Fully Implemented |

## 3.4.2 Mcu Requirements Deviations

Table 3.3 Mcu Requirements Deviations

| Requirement   | Status | Description                                                                                                                                                                                                            | Notes                                                                                                                                                                                                                  |
|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWS_Mcu_00053 | N/S    | If clock failure notification is enabled in the configuration set and a clock source failure error occurs, the error code MCU_ $\leftarrow$ E_CLOCK_FAILURE shall be reported. (See also SWS_ $\leftarrow$ Mcu_00051). | DEMs cannot be reported in I← SR contexts. For the clock failure case the error MCU_E_IS← R_CLOCK_FAILURE was defined and if the error notification is configured by the application the CMU interrupt will report it. |

| Requirement          | Status | Description                                                                                                                                                             | Notes                                                                                                                                                                       |
|----------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWS_Mcu_00056        | N/S    | The function Mcu_Distribute← PllClock shall return without affecting the MCU hardware if the PLL clock has been automatically activated by the MCU hardware. (BSW12336) | The function Mcu_Distribute← PllClock will change the Mcu hardware. The clock switching to PLL is not completed by Mcu_InitClock.                                           |
| SWS_Mcu_00245        | N/S    | If the register can affect several hardware modules and if it is not an I/O register, it shall be initialised by this MCU driver. (BSW12125, BSW12461)                  | There is a separate plug-in that will cover shared ip's.                                                                                                                    |
| SWS_Mcu_00257        | N/S    | Fail criteria for MCU_E_CL← OCK_FAILURE: a clock source failure occurs                                                                                                  | For the clock failure case the error MCU_E_ISR_CLOCK_← FAILURE was defined and if the error notification is configured by the application the CMU interrupt will report it. |
| SWS_Mcu_00258        | N/S    | Pass criteria for MCU_E_← CLOCK_FAILURE: no clock source failure occurs                                                                                                 | For the clock failure case the error MCU_E_ISR_CLOCK_← FAILURE was defined and if the error notification is configured by the application the CMU interrupt will report it. |
| SWS_Mcu_00259        | N/S    | DRAFT: The MCU Driver module shall reject configurations with partition mappings which are not supported by the implementation.                                         | Based on ticket AAI-462, this requirement is not applicable.                                                                                                                |
| SWS_Mcu_CONSTR_00001 | N/S    | DRAFT: The module will operate as an independent instance in each of the partitions, means the called API will only target the partition it is called in.               | Based on ticket AAI-462, this requirement is not applicable.                                                                                                                |
| CPR_RTD_00544.mcu    | N/F    | Driver shall support Autosar standard configuration format for the IP layer Note: EPD file for the IP shall be provided.                                                | For S32K3XX,S32K1, CLOCK IP can't be supported because it will break compatibility.                                                                                         |

## 3.5 Driver Limitations

- Can't disable FIRC clock.
- The notifications did not support in IPL.
- In IPL, the interrupt handler function for PMC and CMU are implemented separately: an interrupt handler function for only PMC and a similar one for CMU. Interrupt hander function that controls both CMU and PMC isn't supported.
- Errata e011063 SMC: An asynchronous wakeup event during VLPS mode entry may result in possible system hang scenario (exist only on S32K14x).

#### Driver

- Errata e011114 and e050383( exist on S32K144w, S32M24x) SMC: invalid data might be fetched while accessing Flash in VLP modes.
- The power mode change notification function will not work without a previously initialized Clock driver. If done otherwise the system clock will not be updated correctly when power mode is changed.

### 3.6 Driver usage and configuration tips

#### 3.6.1 MCU Clock Management

• To generate a clock configuration in Clock Tool from Design Studio, a new project must be created. Project is created with an example clock configuration ClockConfig0. To create a new configuration from scratch (reset configuration), "add a new functional group" button must be pressed. To create a new configuration from an existing one, "copy functional group" button must be pressed. Clock configuration can be removed by removing functional group.



Figure 3.1 Clock tool snapshot for Functional Group Properties

• For reconfiguring the PLLs using Mcu\_InitClock and Mcu\_DistributePllClock the peripherals that are clocked using the PLL that needs to be reconfigured should be turned OFF using Mcu\_SetMode to transition in a mode where that peripheral is OFF.

- For bypassing the configuration of a clock source during Mcu\_InitClock, the "[source] under MCU control" checkbox should be unchecked. This will generate smaller configurations that will be updated faster and more efficiently. In addition, if the application is configuring some clocks in advance, the UnderMcuControl should be unchecked so the MCU driver does not overwrite the initial settings.
- When the clock tree is initialized before the MCU driver is used. e.g The bootloader or user code initializes the clock tree. After that the control is passed to AUTOSAR software, the MCU is used to configured the ECU and clock again. The following sequence is required to successfully and safely re-configure the clock tree.
- System clock frequency selected must adhere to the same clock divider ratios shown in Clocking use case examples of Reference Manual.
- If you want to use peripheral module, you must enable clock gate corresponding to the module in Mcu← PeripheralClockConfig container.
- 1. Mcu\_Init
- 2. Mcu\_InitClock (This function is only called in Run mode.)
- 3. If the PLL is used as a clock source, call Mcu\_GetPllStatus until it returns MCU\_PLL\_LOCKED and call Mcu\_DistributePllClock.
- 4. Mcu SetMode

#### 3.6.2 Specific clock use case:

- The protocol clock of FlexCan has two clock source SOSC and SYS\_CLK, which control by CAN.CTRL1[C← LKSRC]. When SOSC is selected, SYS\_CLK must be greater than 1.5x the protocol clock. When SYS\_CLK is selected, the ratio of SYS\_CLK and FLEXCAN\_CLK can be 1:1.
- Maximum supported clock out frequency for this device is 20 MHz. There is no restrict corresponding to this
  range in EB Tresos due to frequency of CLKOUT is depended on working mode.

#### 3.6.3 MCU Mode Management

• NA

#### 3.6.4 MCU RAM Configuration

• NA

### 3.7 Runtime errors

The driver generates the following DET errors at runtime.

Table 3.4 Default Errors (reported by DET)

#### Driver

| Function                           | Error Code                        | Condition triggering the error                           |
|------------------------------------|-----------------------------------|----------------------------------------------------------|
| Mcu_Init                           | MCU_E_INIT_FAILED                 | Invalid configuration pointer.                           |
| Mcu_InitClock                      | MCU_E_PARAM_CLOCK                 | Invalid input parameter.                                 |
| Mcu_SetMode                        | MCU_E_PARAM_MODE                  | Invalid input parameter.                                 |
| Mcu_InitRamSection                 | MCU_E_PARAM_RAMSECTI←<br>ON       | Invalid input parameter or invalid memory configuration. |
| Mcu_DistributePllClock             | MCU_E_PLL_NOT_LOCKED              | One of the used PLL's failed to achieve lock             |
| All functions, except Mcu_Init and | MCU_E_UNINIT                      | The driver is in an uninitialized                        |
| Mcu_GetVersionInfo                 |                                   | state.                                                   |
| $Mcu\_GetMidrStructure$            | MCU_E_PARAM_POINTER               | Invalid input parameter.                                 |
| Mcu_GetVersionInfo                 | MCU_E_PARAM_POINTER               | Invalid input parameter.                                 |
| Mcu_Init                           | MCU_E_ALREADY_INITIALI↔           | The driver is already initialized.                       |
|                                    | ZED                               |                                                          |
| Mcu_DisableCmu                     | MCU_E_CMU_INDEX_OUT↔<br>_OF_RANGE | Invalid input parameter.                                 |

The driver generates the following DEM errors at runtime.

Table 3.6 Default Errors (reported by DEM)

| Function              | Error Code           | Condition triggering the error           |
|-----------------------|----------------------|------------------------------------------|
| $Mcu\_GetResetReason$ | Mcu_E_TimeoutFailure | Reset flags could not be cleared.        |
| Mcu_GetResetRawValue  | Mcu_E_TimeoutFailure | Reset flags could not be cleared.        |
| Mcu_SetMode           | Mcu_E_TimeoutFailure | The MC_ME or LPU mode transition failed. |
| Mcu_Init              | Mcu_E_TimeoutFailure | The MC_ME mode transition failed.        |
| Mcu_InitClock         | Mcu_E_TimeoutFailure | The MC_ME mode transition failed.        |
| Mcu_DisableCmu        | Mcu_E_TimeoutFailure | Disable CMU failed.                      |
| Mcu_GetRamState       | Mcu_E_TimeoutFailure | Get RAM state failed.                    |

# 3.8 Symbolic Names Disclaimer

All containers having symbolicNameValue set to TRUE in the AUTOSAR schema will generate defines like:

#define <Mip>Conf\_<Container\_ShortName>\_<Container\_ID>

For this reason it is forbidden to duplicate the names of such containers across the RTD configurations or to use names that may trigger other compile issues (e.g. match existing #ifdefs arguments).

# **Chapter 4**

# **Tresos Configuration Plug-in**

This chapter describes the Tresos configuration plug-in for the driver. All the parameters are described below.

- Module Mcu
  - Container McuGeneralConfiguration
    - \* Parameter McuDevErrorDetect
    - \* Parameter McuVersionInfoApi
    - \* Parameter McuGetRamStateApi
    - \* Parameter McuInitClock
    - \* Parameter McuNoPll
    - \* Parameter McuEnterLowPowerMode
    - \* Parameter McuTimeout
    - \* Parameter McuEnableUserModeSupport
    - \* Parameter McuPerformResetApi
    - \* Parameter McuCalloutBeforePerformReset
    - $* \ Parameter \ McuVeryLowPowerStopAbortNotification \\$
    - \* Parameter McuPerformResetCallout
    - \* Parameter McuCmuNotification
    - \* Parameter McuCmuErrorIsrUsed
    - \* Parameter McuErrorIsrNotification
    - \* Parameter McuDisableRcmInit
    - \* Parameter McuDisablePmcInit
    - \* Parameter McuDisableSmcInit
    - \* Parameter McuEnableModeChangeNotification
    - \* Parameter McuTimeoutMethod
    - \* Parameter McuRegisterValuesOptimization
    - \* Reference McuEcucPartitionRef
  - Container McuDebugConfiguration
    - \* Parameter McuDisableDemReportErrorStatus
    - \* Parameter McuGetMidrStructureApi
    - \* Parameter McuDisableCmuApi
    - \* Parameter McuEnablePeripheralCMU
    - \* Parameter McuSRAMRetentionConfigApi

- \* Parameter McuGetClockFrequencyApi
- \* Parameter McuGetPowerModeStatetApi
- \* Parameter McuPmcAeConfigApi
- \* Parameter McuAecResetConfigApi
- Container McuPublishedInformation
  - \* Container McuResetReasonConf
    - · Parameter McuResetReason
- Container CommonPublishedInformation
  - \* Parameter ArReleaseMajorVersion
  - \* Parameter ArReleaseMinorVersion
  - \* Parameter ArReleaseRevisionVersion
  - \* Parameter ModuleId
  - \* Parameter SwMajorVersion
  - \* Parameter SwMinorVersion
  - \* Parameter SwPatchVersion
  - \* Parameter VendorApiInfix
  - \* Parameter VendorId
- Container McuModuleConfiguration
  - \* Parameter McuNumberOfMcuModes
  - \* Parameter McuRamSectors
  - \* Parameter McuResetSetting
  - \* Parameter McuRTC CLKINFrequencyHz
  - \* Parameter McuTCLK0\_REF\_CLKFrequencyHz
  - \* Parameter McuTCLK1\_REF\_CLKFrequencyHz
  - \* Parameter McuTCLK2 REF CLKFrequencyHz
  - \* Parameter McuClockSrcFailureNotification
  - \* Container McuAllowedModes
    - · Parameter McuAllowHighSpeedRunMode
    - · Parameter McuAllowVeryLowPowerModes
  - \* Container McuClockSettingConfig
    - · Parameter McuClockSettingId
    - · Parameter McuSysClockUnderMcuControl
    - · Parameter McuScgClkOutSelect
    - · Container McuRunClockConfig
    - · Parameter McuPreDivSystemClockFrequency
    - · Parameter McuCoreClockFrequency
    - · Parameter McuSystemClockFrequency
    - · Parameter McuBusClockFrequency
    - · Parameter McuFlashClockFrequency
    - · Parameter McuSystemClockSwitch
    - · Parameter McuCoreClockDivider
    - · Parameter McuBusClockDivider
    - · Parameter McuSlowClockDivider
    - · Parameter McuScgClkOutFrequency
    - · Container McuVlprClockConfig
    - · Parameter McuPreDivSystemClockFrequency

- · Parameter McuCoreClockFrequency
- · Parameter McuSystemClockFrequency
- · Parameter McuBusClockFrequency
- · Parameter McuFlashClockFrequency
- · Parameter McuSystemClockSwitch
- · Parameter McuCoreClockDivider
- · Parameter McuBusClockDivider
- · Parameter McuSlowClockDivider
- · Parameter McuScgClkOutFrequency
- · Container McuHsrunClockConfig
- · Parameter McuPreDivSystemClockFrequency
- Parameter McuCoreClockFrequency
- · Parameter McuSystemClockFrequency
- · Parameter McuBusClockFrequency
- · Parameter McuFlashClockFrequency
- · Parameter McuSystemClockSwitch
- · Parameter McuCoreClockDivider
- · Parameter McuBusClockDivider
- $\cdot \ \ Parameter \ McuSlowClockDivider$
- $\cdot \ \ Parameter \ McuScgClkOutFrequency$
- · Container McuSystemOSCClockConfig
- $\cdot \ \ Parameter \ McuSOSCUnder McuControl$
- $\cdot \ \ Parameter \ McuSOSCF requency$
- · Parameter McuSOSCDiv2Frequency
- · Parameter McuSOSCDiv1Frequency
- · Parameter McuSOSCEnable
- $\cdot \ \ Parameter \ McuSOSCClockMonitorResetEnable$
- · Parameter McuSOSCClockMonitorEnable
- · Parameter McuSOSCDiv2
- · Parameter McuSOSCDiv1
- · Parameter McuSOSCRangeSelect
- · Parameter McuSOSCHighGainOscillatorSelect
- · Parameter McuSOSCExternalReferenceSelect
- · Container McuSIRCClockConfig
- · Parameter McuSIRCUnderMcuControl
- · Parameter McuSIRCFrequency
- · Parameter McuSIRCDiv2Frequency
- · Parameter McuSIRCDiv1Frequency
- · Parameter McuSIRCEnable
- · Parameter McuSIRCLowPowerEnable
- · Parameter McuSIRCStopEnable
- · Parameter McuSIRCDiv2
- · Parameter McuSIRCDiv1
- · Parameter McuSIRCRangeSelect
- · Container McuFIRCClockConfig
- · Parameter McuFIRCUnderMcuControl
- · Parameter McuFIRCFrequency

- · Parameter McuFIRCDiv2Frequency
- · Parameter McuFIRCDiv1Frequency
- · Parameter McuFIRCEnable
- · Parameter McuFIRCRegulatorEnable
- · Parameter McuFIRCDiv2
- · Parameter McuFIRCDiv1
- · Parameter McuFIRCRangeSelect
- · Container McuSystemPll
- · Parameter McuSystemPllUnderMcuControl
- · Parameter McuSPLLFrequency
- · Parameter McuSPLLDiv2Frequency
- · Parameter McuSPLLDiv1Frequency
- · Parameter McuSPLLEnable
- · Parameter McuSPLLClockMonitorResetEnable
- · Parameter McuSPLLClockMonitorEnable
- · Parameter McuSPLLDiv2
- · Parameter McuSPLLDiv1
- · Parameter McuSPLLInputClkPreDivider
- · Parameter McuSPLLReferenceFrequency
- · Parameter McuSPLLInputFrequency
- · Parameter McuSPLLMultiplier
- · Parameter McuSPLLSelectSourceClock
- · Container McuSIMClockConfig
- · Parameter McuSIMUnderMcuControl
- · Parameter McuEIMClockGatingEnable
- · Parameter McuERMClockGatingEnable
- · Parameter McuDMAClockGatingEnable
- · Parameter McuMPUClockGatingEnable
- · Parameter McuMSCMClockGatingEnable
- $\cdot \ \ Parameter \ McuGPIOClockGatingEnable$
- · Container McuSimChipConfiguration
- · Parameter McuDebugTraceDividerEnable
- · Parameter McuTRACECLKDivider
- · Parameter McuTRACECLKFraction
- · Parameter McuTRACECLKSelect
- · Parameter McuCLKOUTEnable
- · Parameter McuCLKOUTDivider
- · Parameter McuCLKOUTSelect
- · Container McuSimLpoConfiguration
- · Parameter McuRTCClkSelect
- · Parameter McuLPOClkSelect
- · Parameter McuLPO\_32KClockEnable
- · Parameter McuLPO 1KClockEnable
- · Container McuSimFtmConfiguration
- · Parameter McuFTM3ExternalClockPinSelect
- · Parameter McuFTM2ExternalClockPinSelect
- · Parameter McuFTM1ExternalClockPinSelect

- · Parameter McuFTM0ExternalClockPinSelect
- · Parameter McuFTM7ExternalClockPinSelect
- · Parameter McuFTM6ExternalClockPinSelect
- · Parameter McuFTM5ExternalClockPinSelect
- · Parameter McuFTM4ExternalClockPinSelect
- · Container McuClkMonitor
- · Container McuClkMonitor 0
- · Parameter McuClockMonitorUnderMcuControl
- · Parameter McuClkMonitorEn
- · Parameter McuCmuName
- · Parameter McuAsyncFHHInterruptEn
- · Parameter McuAsyncFLLInterruptEn
- · Container McuClkMonitor 1
- · Parameter McuClockMonitorUnderMcuControl
- · Parameter McuClkMonitorEn
- · Parameter McuCmuName
- · Parameter McuSyncFHHInterruptEn
- $\cdot \ \ Parameter \ McuSyncFLLInterruptEn$
- · Container McuPeripheralClockConfig
- $\cdot \ \ Parameter \ McuPeripheral Clock Under McuControl$
- · Parameter McuPerName
- $\cdot \ \ Parameter \ McuPeripheral Clock Enable$
- · Parameter McuPeripheralClockSelect
- · Parameter McuPeripheralClockDivider
- · Parameter McuPeripheralFractionalDivider
- · Parameter McuPeripheralClockFrequency
- · Container McuClockReferencePoint
- · Parameter McuClockReferencePointFrequency
- · Parameter McuClockFrequencySelect
- \* Container McuDemEventParameterRefs
  - · Reference MCU E TIMEOUT FAILURE
  - · Reference MCU\_E\_CLOCK\_FAILURE
  - · Reference MCU\_E\_SWITCHMODE\_FAILURE
- \* Container McuModeSettingConf
  - · Parameter McuMode
  - · Parameter McuPowerMode
  - · Parameter McuEnableSleepOnExit
- \* Container McuRamSectorSettingConf
  - · Parameter McuRamSectorId
  - · Parameter McuRamDefaultValue
  - · Parameter McuRamSectionBaseAddress
  - · Parameter McuRamSectionSize
  - · Parameter McuRamSectionWriteSize
  - $\cdot \ \, Parameter \ \, McuRam Section Base Addr Linker Sym$
  - · Parameter McuRamSectionSizeLinkerSym
- \* Container McuInterruptEvents
  - · Parameter McuVoltageErrorEvent

- · Parameter McuAlternateResetEvent
- \* Container McuResetConfig
  - · Parameter McuResetPinFilterBusClockSelect
  - · Parameter McuResetPinFilterInStopMode
  - · Parameter McuResetPinFilterInRunAndWait
  - · Container McuSystemInterruptEnable
  - · Parameter McuResetDelayTime
  - · Parameter McuStopAcknowledgeErrorInterrupt
  - · Parameter McuMDMAPSystemResetInterrupt
  - · Parameter McuSoftwareInterrupt
  - · Parameter McuCoreLockupInterrupt
  - · Parameter McuJTAGResetInterrupt
  - · Parameter McuGlobalInterrupt
  - · Parameter McuExternalResetPinInterrupt
  - · Parameter McuWatchdogInterrupt
  - · Parameter McuCMULossOfClockResetInterrupt
  - · Parameter McuLossOfLockInterrupt
  - · Parameter McuLossOfClockInterrupt
  - · Container McuResetGeneratorConfiguration
  - · Parameter McuRegsOtpReset
  - · Parameter McuCanPhyReset
  - · Parameter McuLinPhyHpReset
  - · Parameter McuLinPhyLpReset
  - · Parameter McuGduReset
  - · Parameter McuHviReset
  - · Parameter McuDpgaReset
  - $\cdot \ \ Parameter \ McuTempsensorReset$
  - · Parameter McuCxpiReset
- \* Container McuPowerControl
  - · Container McuPMC Config
  - $\cdot \ \ Parameter \ McuLowVoltageDetectInterruptEnable$
  - · Parameter McuLowVoltageDetectResetEnable
  - $\cdot \ \ Parameter \ McuLowVoltage Warning Interrupt Enable$
  - · Parameter McuLPODisable
  - · Parameter McuClockBiasDisable
  - · Parameter McuLowPowerBiasEnable
  - · Container McuPMC\_AE\_Config
  - $\cdot \ \ Parameter \ McuLowVoltageDetectInterruptsOnVLSEnable$
  - $\cdot \quad Parameter \ McuLowVoltageDetectInterruptsOnVDDCE nable$
  - $\cdot \ \ Parameter \ McuHighVoltageDetectInterruptOnVDDEnable$
  - $\cdot \quad Parameter \ McuHighVoltageDetectInterruptOnVDDINTAndVDD15Enable$
  - · Parameter McuLinphySupplyEnable
  - · Parameter McuVDDCEnable
  - · Parameter McuLvdVlsSelect
  - · Parameter McuLinphySupplySelect
  - · Parameter McuVddVoltageLevelSelect

## 4.1 Module Mcu

Configuration of the MicroController Unit (MCU) module.

Included containers:

- McuGeneralConfiguration
- $\bullet \quad {\bf McuDebugConfiguration}\\$
- McuPublishedInformation
- CommonPublishedInformation
- McuModuleConfiguration

| Property                | Value                                   |
|-------------------------|-----------------------------------------|
| type                    | ECUC-MODULE-DEF                         |
| lowerMultiplicity       | 1                                       |
| upperMultiplicity       | 1                                       |
| postBuildVariantSupport | true                                    |
| supportedConfigVariants | VARIANT-POST-BUILD, VARIANT-PRE-COMPILE |

# 4.2 Container McuGeneralConfiguration

This container contains the general configuration for the MCU driver.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

### 4.3 Parameter McuDevErrorDetect

Pre-processor switch for enabling the default error detection and reporting to the DET.

The switch McuDevErrorDetect shall switch the Default Error Tracer (Det) detection and notification ON or OFF.

The detection of default errors is configurable (ON/OFF) at precompile time.

 $\# define\ MCU\_DEV\_ERROR\_DETECT\ (STD\_ON)/(STD\_OFF)\ will\ be\ generated\ in\ Mcu\_Cfg.h\ file.$ 

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.4 Parameter McuVersionInfoApi

Pre-processor switch to enable/disable the API to read out the modules version information.

#define MCU\_VERSION\_INFO\_API (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.5 Parameter McuGetRamStateApi

Pre-processor switch to enable/disable the API Mcu\_GetRamState.

 $\# define\ MCU\_GET\_RAM\_STATE\_API\ (STD\_ON)/(STD\_OFF)\ will\ be\ generated\ in\ Mcu\_Cfg.h\ file.$ 

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | false                            |

### 4.6 Parameter McuInitClock

If this parameter is set to FALSE, the clock initialization has to be disabled from the MCU driver. This concept applies when there are some write once clock registers and a bootloader is present. If this parameter is set to TRUE, the MCU driver is responsible of the clock initialization

#define MCU\_INIT\_CLOCK (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | true                             |

## 4.7 Parameter McuNoPll

This parameter shall be set True, if the H/W does not have a PLL or the PLL circuitry is enabled after the power on without S/W intervention. In this case MCU\_DistributePllClock has to be disabled and MCU\_GetPllStatus has to return MCU\_PLL\_STATUS\_UNDEFINED. Otherwise this parameters has to be set False.

#define MCU\_NO\_PLL (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | true                             |

### 4.8 Parameter McuEnterLowPowerMode

If this parameter has been configured to 'TRUE', the function 'Mcu\_SetMode()' shall not be impacted and behave as specified.

If this parameter has been configured to 'FALSE', the function 'Mcu\_SetMode()' shall not perform the transition to any low power modes as are 'STOP' or 'HALT' or any other mode, where the core stops execution.

#define MCU\_ENTER\_LOW\_POWER\_MODE (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | true                             |

### 4.9 Parameter McuTimeout

This parameter represents the maximum number of loops for blocking functionality.

The maximum time needed for a MC\_ME transition from DRUN to DRUN with keeping PLL running is 3 ms.

Please take this into consideration when choosing the value for this parameter.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | 50000                            |
| max                          | 4294967295                       |
| min                          | 0                                |

# 4.10 Parameter McuEnableUserModeSupport

When this parameter is enabled, the MDL module will adapt to run from User Mode, with the following measures:

- a) using 'call trusted function' stubs for all internal function calls that access registers requiring supervisor mode.
- b) other module specific measures

for more information, please see chapter 5.7 User Mode Support in IM

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.11 Parameter McuPerformResetApi

Pre-processor switch to enable/disable the use the Mcu\_PerformReset() API.

OFF - Mcu\_PerformReset() API is not used.

ON - Mcu\_PerformReset() API is used.

#define MCU\_PERFORM\_RESET\_API (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.12 Parameter McuCalloutBeforePerformReset

Check this if you want a callout function, called by MCU right before Mcu\_PerformReset().

This parameter is available for configuration only if "McuPerformResetApi" is ON.

#define MCU\_RESET\_CALLOUT\_USED (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.13 Parameter McuVeryLowPowerStopAbortNotification

Function name of callout. This function will be called when entering VLPS is aborted.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FUNCTION-NAME-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | NULL_PTR                         |

## 4.14 Parameter McuPerformResetCallout

Function name of callout.

The field is editable only if "McuCalloutBeforePerformReset" is ON.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FUNCTION-NAME-DEF           |
| origin                       | NXP                              |
| ${\it symbolic} Name Value$  | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | NULL_PTR                         |

## 4.15 Parameter McuCmuNotification

Function pointer to callback function.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FUNCTION-NAME-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | NULL_PTR                         |

### 4.16 Parameter McuCmuErrorIsrUsed

 $\label{lem:configuration} Check this if clock source failure notifications are enabled (i.e.\ McuModuleConfiguration/McuClockSrcFailureNotification = 'ENABLED').$ 

#define MCU\_CMU\_ERROR\_ISR\_USED (STD\_ON)/(STD\_OFF) will be generated in Mcu\_Cfg.h file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

### 4.17 Parameter McuErrorIsrNotification

Function name of callout. This function will be called by the error ISR.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FUNCTION-NAME-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | NULL_PTR                         |

### 4.18 Parameter McuDisableRcmInit

To allow integration with non-Autosar Application Initialization so that settings done by AppInit will not to be done again by MCU driver.

If this parameter is set to TRUE, the Reset Control Module (RMC) initialization has to be disabled in the MCU driver.

If this parameter is set to FALSE, the MCU driver is responsible for the Reset Control Module (RMC) initialization.

 $\# define\ POWER\_IP\_DISABLE\_RCM\_INIT\ (STD\_ON)/(STD\_OFF)\ will\ be\ generated\ in\ Power\_Ip\_Cfg\_Defines. he file.$ 

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | false                            |

### 4.19 Parameter McuDisablePmcInit

To allow integration with non-Autosar Application Initialization so that settings done by AppInit will not to be done again by MCU driver.

If this parameter is set to TRUE, the Power Management Controller (PMC) initialization has to be disabled in the MCU driver.

If this parameter is set to FALSE, the MCU driver is responsible for the Power Management Controller (PMC) initialization.

 $\# define\ POWER\_IP\_DISABLE\_PMC\_INIT\ (STD\_ON)/(STD\_OFF)\ will\ be\ generated\ in\ Power\_Ip\_Cfg\_Defines. In the property of t$ 

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | false                            |

### 4.20 Parameter McuDisableSmcInit

To allow integration with non-Autosar Application Initialization so that settings done by AppInit will not to be done again by MCU driver.

If this parameter is set to TRUE, the System Mode Controller (SMC) initialization has to be disabled in the MCU driver.

If this parameter is set to FALSE, the MCU driver is responsible for the System Mode Controller (SMC) initialization.

 $\# define\ POWER\_IP\_DISABLE\_SMC\_INIT\ (STD\_ON)/(STD\_OFF)\ will\ be\ generated\ in\ Power\_Ip\_Cfg\_Defines. In the property of t$ 

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-BOOLEAN-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |
| lowerMultiplicity | 1                      |
| upperMultiplicity | 1                      |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | false                            |

## 4.21 Parameter McuEnableModeChangeNotification

If this parameter is set to TRUE, the Power Driver will send notifications to Clock driver when power mode is changed.

If this parameter is set to FALSE, the Power Driver will not send notifications to Clock driver when power mode is changed.

 $\# define\ POWER\_MODE\_CHANGE\_NOTIFICATION\ (STD\_ON)/(STD\_OFF)\ will\ be\ generated\ in\ Power\_Ip\_Cfg\_Defines.$  file.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | false                            |

## 4.22 Parameter McuTimeoutMethod

McuTimeoutMethod

Configures the timeout method.

Based on this selection a certain timeout method from OsIf will be used in the driver.

Note: If OSIF\_COUNTER\_SYSTEM or OSIF\_COUNTER\_CUSTOM are selected make sure the corresponding timer is enabled in OsIf General configuration.

| Property                     | Value                                                                  |
|------------------------------|------------------------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                             |
| origin                       | NXP                                                                    |
| symbolicNameValue            | false                                                                  |
| lowerMultiplicity            | 1                                                                      |
| upperMultiplicity            | 1                                                                      |
| postBuildVariantMultiplicity | N/A                                                                    |
| multiplicityConfigClasses    | N/A                                                                    |
| postBuildVariantValue        | false                                                                  |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                                       |
| varueComigClasses            | VARIANT-POST-BUILD: PRE-COMPILE                                        |
| defaultValue                 | OSIF_COUNTER_DUMMY                                                     |
| literals                     | ['OSIF_COUNTER_DUMMY', 'OSIF_COUNTER_SYSTEM', 'OSIF_COU↔ NTER_CUSTOM'] |

## 4.23 Parameter McuRegisterValuesOptimization

Check this if register values of CMUs, PCFS will be generated by configuration tool.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | DISABLED                         |
| literals                     | ['ENABLED', 'DISABLED']          |

# 4.24 Reference McuEcucPartitionRef

Maps the MCU driver to zero or multiple ECUC partitions to make the

modules API available in this partition.

Tags: atp.Status=draft

| Property                             | Value                                                        |
|--------------------------------------|--------------------------------------------------------------|
| type                                 | ECUC-REFERENCE-DEF                                           |
| origin                               | AUTOSAR_ECUC                                                 |
| lowerMultiplicity                    | 0                                                            |
| upperMultiplicity                    | Infinite                                                     |
| postBuildVariantMultiplicity         | true                                                         |
| multiplicityConfigClasses            | VARIANT-PRE-COMPILE: PRE-COMPILE                             |
| multiplicity ComigClasses            | VARIANT-POST-BUILD: PRE-COMPILE                              |
| postBuildVariantValue                | true                                                         |
| valueConfigClasses                   | VARIANT-PRE-COMPILE: PRE-COMPILE                             |
| varueConnigCrasses                   | VARIANT-POST-BUILD: PRE-COMPILE                              |
| ${\it requires Symbolic Name Value}$ | False                                                        |
| destination                          | /AUTOSAR/EcucDefs/EcuC/EcucPartitionCollection/EcucPartition |

# 4.25 Container McuDebugConfiguration

This container contains option for non-ASR APIs used for debug or extra-implementation.

Note: Implementation Specific Parameter.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# ${\bf 4.26} \quad {\bf Parameter} \ {\bf McuDisable Dem Report Error Status}$

Enable/Disable the API for reporting the Dem Error.

| Property | Value                  |
|----------|------------------------|
| type     | ECUC-BOOLEAN-PARAM-DEF |
| origin   | NXP                    |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.27 Parameter McuGetMidrStructureApi

Enable/Disable the API for Mcu\_GetMidrStructure().

Get information from SIUL2 MIDRn registers.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.28 Parameter McuDisableCmuApi

Enable/Disable the API for disabling the clock monitoring unit.

| Property | Value                  |
|----------|------------------------|
| type     | ECUC-BOOLEAN-PARAM-DEF |
| origin   | NXP                    |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.29 Parameter McuEnablePeripheralCMU

Enable/Disable Peripheral CMU for S32K11X

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.30 Parameter McuSRAMRetentionConfigApi

 $\operatorname{Enable/Disable}$  the API for SRAM retention configuration.

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-BOOLEAN-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |
| lowerMultiplicity | 1                      |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.31 Parameter McuGetClockFrequencyApi

Enable/Disable the API for Mcu\_GetClockFrequency().

Return the frequency of a given clock.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.32 Parameter McuGetPowerModeStatetApi

Enable/Disable the API for Get Power Mode state: Mcu\_GetPowerMode\_State().

Get information regarding current power mode, enabled clocks, etc (content of SMC\_PMSTART register).

| Property | Value                  |
|----------|------------------------|
| type     | ECUC-BOOLEAN-PARAM-DEF |
| origin   | NXP                    |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.33 Parameter McuPmcAeConfigApi

Enable/Disable the API for Mcu\_PmcAeConfig().

Configure the Power Management Controller AE.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.34 Parameter McuAecResetConfigApi

Enable/Disable the API for Mcu\_AecResetConfig().

Configure the reset generator AEC.

| Property | Value                  |
|----------|------------------------|
| type     | ECUC-BOOLEAN-PARAM-DEF |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| origin                       | NXP                              |
| ${\it symbolic} Name Value$  | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

### 4.35 Container McuPublishedInformation

Container holding all MCU specific published information parameters.

Included subcontainers:

#### • McuResetReasonConf

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# 4.36 Container McuResetReasonConf

This container contains the configuration for the different type of reset reason that can be retrieved from  $Mcu\_GetResetReason$  Api.

Included subcontainers:

#### • None

| Property          | Value                         |
|-------------------|-------------------------------|
| type              | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity | 1                             |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| upperMultiplicity            | Infinite                         |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |

## 4.37 Parameter McuResetReason

The parameter represents the different type of reset that a Micro supports. This parameter is referenced by the parameter EcuMResetReason in the ECU State manager module.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | true                             |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | 5                                |
| max                          | 255                              |
| min                          | 0                                |

### 4.38 Container CommonPublishedInformation

Common container, aggregated by all modules.

It contains published information about vendor and versions.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.39 Parameter ArReleaseMajorVersion

Major version number of AUTOSAR specification on which the appropriate implementation is based on.

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 4                                          |
| max                          | 4                                          |
| min                          | 4                                          |

### 4.40 Parameter ArReleaseMinorVersion

Minor version number of AUTOSAR specification on which the appropriate implementation is based on.

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 7                                          |
| max                          | 7                                          |
| min                          | 7                                          |

### 4.41 Parameter ArReleaseRevisionVersion

Revision version number of AUTOSAR specification on which the appropriate implementation is based on.

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 0                                          |
| max                          | 0                                          |
| min                          | 0                                          |

### 4.42 Parameter ModuleId

Module ID of this module from Module List.

Note: Implementation Specific Parameter

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 101                                        |
| max                          | 101                                        |
| min                          | 101                                        |

## 4.43 Parameter SwMajorVersion

Major version number of the vendor specific implementation of the module. The numbering is vendor specific.

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 2                                          |
| max                          | 2                                          |
| min                          | 2                                          |

### 4.44 Parameter SwMinorVersion

Minor version number of the vendor specific implementation of the module. The numbering is vendor specific.

Note: Implementation Specific Parameter

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 0                                          |
| max                          | 0                                          |
| min                          | 0                                          |

### 4.45 Parameter SwPatchVersion

Patch level version number of the vendor specific implementation of the module. The numbering is vendor specific.

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 0                                          |
| max                          | 0                                          |
| min                          | 0                                          |

## 4.46 Parameter VendorApiInfix

In driver modules which can be instantiated several times on a single ECU, BSW00347 requires that the name of APIs is extended by the VendorId and a vendor specific name.

This parameter is used to specify the vendor specific name. In total, the Implementation specific name is generated as follows:

E.g. assuming that the VendorId of the implementor is 123 and the implementer chose a VendorApiInfix of "v11r456" a api name

Can\_Write defined in the SWS will translate to Can\_123\_v11r456Write.

This parameter is mandatory for all modules with upper multiplicity >

1. It shall not be used for modules with upper multiplicity =1.

| Property                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Value                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ECUC-STRING-PARAM-DEF                                                 |
| origin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | NXP                                                                   |
| symbolicNameValue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | false                                                                 |
| lowerMultiplicity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                     |
| upperMultiplicity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                     |
| postBuildVariantMultiplicity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | N/A                                                                   |
| multiplicityConfigClasses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | N/A                                                                   |
| postBuildVariantValue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | false                                                                 |
| valueConfigClasses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | VARIANT-POST-BUILD: PUBLISHED-INFORMATION                             |
| NXP Semiconductors Se | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION<br>32K1 S32M24x MCU Driver |
| defaultValue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 52111 S02112 II 1110 0 B11101                                         |

### 4.47 Parameter VendorId

Vendor ID of the dedicated implementation of this module according to the AUTOSAR vendor list.

Note: Implementation Specific Parameter

| Property                     | Value                                      |
|------------------------------|--------------------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF                     |
| origin                       | NXP                                        |
| symbolicNameValue            | false                                      |
| lowerMultiplicity            | 1                                          |
| upperMultiplicity            | 1                                          |
| postBuildVariantMultiplicity | N/A                                        |
| multiplicityConfigClasses    | N/A                                        |
| postBuildVariantValue        | false                                      |
| valueConfigClasses           | VARIANT-POST-BUILD: PUBLISHED-INFORMATION  |
|                              | VARIANT-PRE-COMPILE: PUBLISHED-INFORMATION |
| defaultValue                 | 43                                         |
| max                          | 43                                         |
| min                          | 43                                         |

## 4.48 Container McuModuleConfiguration

This container contains the configuration for the MCU driver.

Included subcontainers:

- $\bullet \quad McuAllowedModes$
- McuClockSettingConfig
- $\bullet \quad McuDemEventParameterRefs$
- $\bullet \quad McuModeSettingConf$
- $\bullet \ \ McuRamSectorSettingConf$
- McuInterruptEvents
- McuResetConfig
- McuPowerControl

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClassex 1  | 32M24x MCII Driver NX         |

### 4.49 Parameter McuNumberOfMcuModes

This parameter shall represent the number of Modes available for the MCU (from "McuModeSettingConf" list).

CalculationFormula = Number of configured "McuModeSettingConf".

This parameter is not used.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-POST-BUILD: POST-BUILD   |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | 1                                |
| max                          | 255                              |
| min                          | 1                                |

### 4.50 Parameter McuRamSectors

This parameter shall represent the number of RAM sectors available for the MCU (from "McuRamSectorSettingConf" list).

 $\label{eq:calculation} Calculation Formula = Number\ of\ configured\ "McuRamSectorSettingConf".$ 

This parameter is not used.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-POST-BUILD: POST-BUILD   |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| defaultValue                 | 1                                |
| max                          | 4294967295                       |
| min<br>ctors S32K1           | 0<br>S32M24x MCU Driver          |

## 4.51 Parameter McuResetSetting

This parameters applies to the function Mcu\_PerformReset(), which performs a microcontroller reset using the hardware feature of the microcontroller.

Note: This parameter is not used by the current Implementation.

Software Reset occurs when Mcu\_PerformReset() function is called.

This parameter is not used.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
| martiplicity comigciasses    | VARIANT-POST-BUILD: PRE-COMPILE  |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | 1                                |
| max                          | 255                              |
| min                          | 1                                |

# 4.52 Parameter McuRTC\_CLKINFrequencyHz

RTC\_CLKIN Frequency [Hz].

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |

| Property     | Value     |
|--------------|-----------|
| defaultValue | 32768.0   |
| max          | 1000000.0 |
| min          | 0.0       |

## 4.53 Parameter McuTCLK0\_REF\_CLKFrequencyHz

TCLK0\_REF\_CLK Frequency [Hz].

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 32000.0                          |
| max                          | 2.0E7                            |
| min                          | 0.0                              |

# 4.54 Parameter McuTCLK1\_REF\_CLKFrequencyHz

TCLK1\_REF\_CLK Frequency [Hz].

| Property                     | Value                |
|------------------------------|----------------------|
| type                         | ECUC-FLOAT-PARAM-DEF |
| origin                       | NXP                  |
| symbolicNameValue            | false                |
| lowerMultiplicity            | 1                    |
| upperMultiplicity            | 1                    |
| postBuildVariantMultiplicity | N/A                  |
| multiplicityConfigClasses    | N/A                  |
| postBuildVariantValue        | true                 |

| Property           | Value                            |
|--------------------|----------------------------------|
| valueConfigClasses | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                    | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue       | 32000.0                          |
| max                | 2.0E7                            |
| min                | 0.0                              |

# ${\bf 4.55} \quad {\bf Parameter} \ {\bf McuTCLK2\_REF\_CLKFrequencyHz}$

TCLK2\_REF\_CLK Frequency [Hz].

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 32000.0                          |
| max                          | 2.0E7                            |
| min                          | 0.0                              |

## 4.56 Parameter McuClockSrcFailureNotification

Enables/Disables clock failure notification.

In case this feature is not supported by HW the setting should be disabled.

| Property          | Value                      |
|-------------------|----------------------------|
| type              | ECUC-ENUMERATION-PARAM-DEF |
| origin            | AUTOSAR_ECUC               |
| symbolicNameValue | false                      |
| lowerMultiplicity | 1                          |
| upperMultiplicity | 1                          |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | DISABLED                         |
| literals                     | ['ENABLED', 'DISABLED']          |

#### 4.57 Container McuAllowedModes

Configures SMC\_PMPROT register. The PMPROT register can be written only once after any system reset.

If the MCU is configured for a disallowed or reserved power mode, the MCU remains in its current power mode.

For example, if the MCU is in normal RUN mode and AVLP is 0, an attempt to enter VLPR mode using PMC-TRL[RUNM] is blocked and PMCTRL[RUNM] remains 00b, indicating the MCU is still in Normal Run mode.

Note: Implementation specific Container.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## ${\bf 4.58} \quad {\bf Parameter} \,\, {\bf McuAllowHighSpeedRunMode}$

This is a write-once parameter

SMC\_PMPROT[AHSRUN] - Allow High Speed Run mode

Provided the appropriate control bits are set up in PMCTRL, this write-once field allows the MCU to enter High Speed Run mode (HSRUN).

0 - HSRUN is not allowed

1 - HSRUN is allowed

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.59 Parameter McuAllowVeryLowPowerModes

This is a write-once parameter

Provided the appropriate control bits are set up in PMCTRL, this write-once field allows the MCU to enter any very-low-power mode (VLPR, and VLPS).

0 - VLPR and VLPS are not allowed.

1 - VLPR and VLPS are allowed.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.60 Container McuClockSettingConfig

This container contains the configuration for the Clock settings of the MCU.

#### Included subcontainers:

- McuRunClockConfig
- McuVlprClockConfig
- McuHsrunClockConfig
- $\bullet \quad McuSystemOSCClockConfig\\$
- $\bullet \ \ McuSIRCClockConfig$
- McuFIRCClockConfig
- $\bullet \quad McuSystemPll \\$
- McuSIMClockConfig
- McuClkMonitor
- $\bullet \quad McuPeripheralClockConfig\\$
- McuClockReferencePoint

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF    |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | Infinite                         |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |

# 4.61 Parameter McuClockSettingId

The Id of this McuClockSettingConfig to be used as argument for the API call Mcu\_InitClock().

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | true                             |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | 0                                |
| max                          | 255                              |
| min                          | 0                                |

## 4.62 Parameter McuSysClockUnderMcuControl

- 0 System clock tree is NOT under mcu control.
- 1 System clock is under mcu control.

If this is set to false, the MCU code will not configure the SCG\_xCCR register when Mcu\_InitClock is called

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

# 4.63 Parameter McuScgClkOutSelect

 $SCG\_CLKOUTCNFG[CLKOUTSEL]$  - SCG Clkout Select.

This register controls which SCG clock source is selected to be ported out to the CLKOUT pin.

- 0 SCG SLOW Clock (FLASH\_CLK Clock).
- 1 System OSC
- 2 Slow IRC
- 3 Fast IRC
- 6 System PLL

The selected clock must be enabled.

| Property | Value                      |
|----------|----------------------------|
| type     | ECUC-ENUMERATION-PARAM-DEF |
| origin   | NXP                        |

| Property                     | Value                                                        |
|------------------------------|--------------------------------------------------------------|
| symbolicNameValue            | false                                                        |
| lowerMultiplicity            | 1                                                            |
| upperMultiplicity            | 1                                                            |
| postBuildVariantMultiplicity | N/A                                                          |
| multiplicityConfigClasses    | N/A                                                          |
| postBuildVariantValue        | true                                                         |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                             |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                               |
| defaultValue                 | SLOW_CLK                                                     |
| literals                     | ['SLOW_CLK', 'SOSC_CLK', 'SIRC_CLK', 'FIRC_CLK', 'SPLL_CLK'] |

## 4.64 Container McuRunClockConfig

This container configures the system clock source and the system clock dividers

for the core, platform, external and bus clock domains when in Run mode only.

Note: Implementation specific Container.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# 4.65 Parameter McuPreDivSystemClockFrequency

Run Core clock - Pre Divide System Clock Frequency.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: PREDIV\_SYS\_CLK is only available in S32K148.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 1.6E8                            |
| min                          | 0.0                              |

# 4.66 Parameter McuCoreClockFrequency

Run Core clock - Clocks the ARM core, divided by DIVCORE bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 8.0E7                            |
| min                          | 0.0                              |

### 4.67 Parameter McuSystemClockFrequency

Run System clock - Clocks the Crossbar, NVIC, Flash controller, FTM and PDB,etc.

RUN\_SYS\_CLK can run up to CORE\_CLK.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8.0E7                            |
| max                          | 8.0E7                            |
| min                          | 0.0                              |

## 4.68 Parameter McuBusClockFrequency

Run Bus clock - BUS\_CLK Clocks the Peripherals, divided by DIVBUS bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

| Property                     | Value                |
|------------------------------|----------------------|
| type                         | ECUC-FLOAT-PARAM-DEF |
| origin                       | NXP                  |
| symbolicNameValue            | false                |
| lowerMultiplicity            | 1                    |
| upperMultiplicity            | 1                    |
| postBuildVariantMultiplicity | N/A                  |

| Property                  | Value                            |
|---------------------------|----------------------------------|
| multiplicityConfigClasses | N/A                              |
| postBuildVariantValue     | true                             |
| valueConfigClasses        | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                           | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue              | 4.0E7                            |
| max                       | 4.8E7                            |
| min                       | 0.0                              |

### 4.69 Parameter McuFlashClockFrequency

Run Flash clock - Clocks the flash module, divided by DIVSLOW bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Configuring RUN\_FLASH\_CLK to lower frequencies than 24MHz (S32K11X) and 20Mhz (S32K14xW and S32M242) and 26.67MHz (S32K14X and S32M241) adds wait states and no power saving. It is recommended to configure it as close to 24MHz or 20Mhz or 26.67MHz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2.0E7                            |
| max                          | 2.0E7                            |
| min                          | 0.0                              |

# 4.70 Parameter McuSystemClockSwitch

Run System Clock Select. Configure the SCG\_RCCR[SCS] register field.

The system clock is either:

- System OSC (SCG\_RCCR[SCS]=1)

- Slow IRC (SCG\_RCCR[SCS]=2)

- Fast IRC (SCG\_RCCR[SCS]=3)

- System PLL (SCG\_RCCR[SCS]=6)

Value extracted from Resource: MCU.RunSystemClkSource.List

The selected clock must be enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                                            |
|------------------------------|--------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                       |
| origin                       | NXP                                              |
| symbolicNameValue            | false                                            |
| lowerMultiplicity            | 1                                                |
| upperMultiplicity            | 1                                                |
| postBuildVariantMultiplicity | N/A                                              |
| multiplicityConfigClasses    | N/A                                              |
| postBuildVariantValue        | true                                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                 |
|                              | VARIANT-POST-BUILD: POST-BUILD                   |
| defaultValue                 | FIRC_CLK                                         |
| literals                     | ['SOSC_CLK', 'SIRC_CLK', 'FIRC_CLK', 'SPLL_CLK'] |

### 4.71 Parameter McuCoreClockDivider

Configures the SCG\_RCCR[DIVCORE] bit field

This parameter represents the core clock divider.

| Property                     | Value                  |
|------------------------------|------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF |
| origin                       | NXP                    |
| symbolicNameValue            | false                  |
| lowerMultiplicity            | 1                      |
| upperMultiplicity            | 1                      |
| postBuildVariantMultiplicity | N/A                    |
| multiplicityConfigClasses    | N/A                    |
| postBuildVariantValue        | true                   |

| Property           | Value                            |
|--------------------|----------------------------------|
| valueConfigClasses | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                    | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue       | 1                                |
| max                | 16                               |
| min                | 1                                |

### 4.72 Parameter McuBusClockDivider

Configures the SCG\_RCCR[DIVBUS] bitfield

This parameter represents the bus clock divider.

Note: implementation specific parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 16                               |
| min                          | 1                                |

## 4.73 Parameter McuSlowClockDivider

Configures the  $SCG\_RCCR[DIVSLOW]$  bitfield.

This parameter represents the flash clock divider.

Note: Configuring DIVSLOW to lower frequencies than supported flash frequencies mentioned in datasheet (fFLASH) adds wait states and no power saving. It is recommended to configure DIVSLOW as close to fFLASH.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 3                                |
| max                          | 8                                |
| min                          | 1                                |

## 4.74 Parameter McuScgClkOutFrequency

This is frequency of SCG clockout. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1000000.0                        |
| max                          | 1.6E8                            |
| min                          | 0.0                              |

# 4.75 Container McuVlprClockConfig

Selects the clock source generating the system clock in VLPR mode.

The clock dividers cannot be changed while in VLPR mode.

They must be programmed prior to entering VLPR mode to guarantee

- the core/system and bus clocks are less than or equal to 4 MHz

- the flash memory clock is less than or equal to 1 MHz.

Note: Implementation specific Container.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.76 Parameter McuPreDivSystemClockFrequency

VLPR Core clock - Pre Divide System Clock Frequency.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: PREDIV\_SYS\_CLK is only available in S32K148.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8000000.0                        |
| max                          | 8000000.0                        |
| min                          | 0.0                              |

### 4.77 Parameter McuCoreClockFrequency

VLPR Core clock - Clocks the ARM core, divided by DIVCORE bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1000000.0                        |
| max                          | 1000000.0                        |
| min                          | 0.0                              |

## 4.78 Parameter McuSystemClockFrequency

VLPR System clock - Clocks the Crossbar, NVIC, Flash controller, FTM and PDB,etc.

VLPR\_SYS\_CLK can run up to CORE\_CLK.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

| Property                     | Value                |
|------------------------------|----------------------|
| type                         | ECUC-FLOAT-PARAM-DEF |
| origin                       | NXP                  |
| symbolicNameValue            | false                |
| lowerMultiplicity            | 1                    |
| upperMultiplicity            | 1                    |
| postBuildVariantMultiplicity | N/A                  |
| multiplicityConfigClasses    | N/A                  |

| Property              | Value                            |
|-----------------------|----------------------------------|
| postBuildVariantValue | true                             |
| valueConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                       | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue          | 1000000.0                        |
| max                   | 1000000.0                        |
| min                   | 0.0                              |

## 4.79 Parameter McuBusClockFrequency

VLPR Bus clock - BUS\_CLK Clocks the Peripherals, divided by DIVBUS bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1000000.0                        |
| max                          | 1000000.0                        |
| min                          | 0.0                              |

## 4.80 Parameter McuFlashClockFrequency

VLPR Flash clock - Clocks the flash module, divided by DIVSLOW bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Configuring VLPR\_FLASH\_CLK to lower frequencies than 1MHz (S32K14X and S32K11X and S32M241) and 0.25MHz (S32K14xW and S32M242) adds wait states and no power saving. It is recommended to configure it as close to 1MHz or 0.25MHz.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 250000.0                         |
| max                          | 250000.0                         |
| min                          | 0.0                              |

## 4.81 Parameter McuSystemClockSwitch

VLPR System Clock Select. Configure the SCG\_VCCR[SCS] register field.

The system clock is either:

- Slow IRC (SCG\_VCCR[SCS]=2)

 $\label{lem:condition} \mbox{Value extracted from Resource: MCU.VlprSystemClkSource.List}$ 

The selected clock must be enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | SIRC_CLK                         |
| literals                     | ['SIRC_CLK']                     |

## 4.82 Parameter McuCoreClockDivider

Configures the  $SCG\_VCCR[DIVCORE]$  bitfield

This parameter represents the core clock divider.

Note: implementation specific parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8                                |
| max                          | 16                               |
| min                          | 1                                |

## 4.83 Parameter McuBusClockDivider

Configures the  $SCG\_VCCR[DIVBUS]$  bitfield

This parameter represents the bus clock divider.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 16                               |
| min                          | 1                                |

### 4.84 Parameter McuSlowClockDivider

Configures the SCG\_VCCR[DIVSLOW] bitfield.

This parameter represents the flash clock divider.

Note: Configuring DIVSLOW to lower frequencies than supported flash frequencies mentioned in datasheet (fFLASH) adds wait states and no power saving. It is recommended to configure DIVSLOW as close to fFLASH.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4                                |
| max                          | 8                                |
| min                          | 1                                |

# 4.85 Parameter McuScgClkOutFrequency

This is frequency of SCG clockout. It is given in Hz.

In VLPR mode, the FIRC, SOSC, SPLL clocks are disabled.

| Property                     | Value                |
|------------------------------|----------------------|
| type                         | ECUC-FLOAT-PARAM-DEF |
| origin                       | NXP                  |
| symbolicNameValue            | false                |
| lowerMultiplicity            | 1                    |
| upperMultiplicity            | 1                    |
| postBuildVariantMultiplicity | N/A                  |
| multiplicityConfigClasses    | N/A                  |
| postBuildVariantValue        | true                 |

| Property           | Value                            |
|--------------------|----------------------------------|
| valueConfigClasses | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                    | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue       | 1000000.0                        |
| max                | 1.6E8                            |
| min                | 0.0                              |

# 4.86 Container McuHsrunClockConfig

This container configures the system clock source and the system clock dividers

for the core, platform, external and bus clock domains when in HSRUN mode only.

Note: Implementation specific Container.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# 4.87 Parameter McuPreDivSystemClockFrequency

HSRUN System clock - Pre Divide System Clock Frequency.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: PREDIV\_SYS\_CLK is only available in S32K148.

| Property          | Value                |
|-------------------|----------------------|
| type              | ECUC-FLOAT-PARAM-DEF |
| origin            | NXP                  |
| symbolicNameValue | false                |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 1.6E8                            |
| min                          | 0.0                              |

# 4.88 Parameter McuCoreClockFrequency

HSRUN Core clock - Clocks the ARM core, divided by DIVCORE bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 1.12E8                           |
| min                          | 0.0                              |

# 4.89 Parameter McuSystemClockFrequency

 $HSRUN\ System\ clock\ -\ Clocks\ the\ Crossbar,\ NVIC,\ Flash\ controller,\ FTM\ and\ PDB, etc.$ 

HSRUN\_SYS\_CLK can run up to CORE\_CLK.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1.12E8                           |
| max                          | 1.12E8                           |
| min                          | 0.0                              |

# 4.90 Parameter McuBusClockFrequency

HSRUN Bus clock - BUS\_CLK Clocks the Peripherals, divided by DIVBUS bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 5.6E7                            |
| max                          | 5.6E7                            |
| min                          | 0.0                              |

### 4.91 Parameter McuFlashClockFrequency

HSRUN Flash clock - Clocks the flash module, divided by DIVSLOW bits inside SCG

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Configuring HSRUN\_FLASH\_CLK to lower frequencies than 28MHz adds wait states and no power saving. It is recommended to configure it as close to 28MHz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2.8E7                            |
| max                          | 2.8E7                            |
| min                          | 0.0                              |

# 4.92 Parameter McuSystemClockSwitch

HSRUN System Clock Select. Configure the SCG\_HCCR[SCS] register field.

The system clock is either:

- Fast IRC (SCG\_HCCR[SCS]=3)
- System PLL (SCG\_HCCR[SCS]=6)

Value extracted from Resource: MCU.HsrunSystemClkSource.List

The selected clock must be enabled.

| Property | Value                      |
|----------|----------------------------|
| type     | ECUC-ENUMERATION-PARAM-DEF |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | FIRC_CLK                         |
| literals                     | ['FIRC_CLK', 'SPLL_CLK']         |

### 4.93 Parameter McuCoreClockDivider

Configures the SCG\_HCCR[DIVCORE] bitfield

This parameter represents the core clock divider.

Note: implementation specific parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 16                               |
| min                          | 1                                |

### 4.94 Parameter McuBusClockDivider

Configures the  $SCG\_HCCR[DIVBUS]$  bitfield

This parameter represents the bus clock divider.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 16                               |
| min                          | 1                                |

### 4.95 Parameter McuSlowClockDivider

Configures the SCG\_HCCR[DIVSLOW] bitfield.

This parameter represents the flash clock divider.

Note: Configuring DIVSLOW to lower frequencies than supported flash frequencies mentioned in datasheet (fFLASH) adds wait states and no power saving. It is recommended to configure DIVSLOW as close to fFLASH.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2                                |
| max                          | 8                                |
| min                          | 1                                |

# 4.96 Parameter McuScgClkOutFrequency

This is frequency of SCG clockout. It is given in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1000000.0                        |
| max                          | 1.6E8                            |
| min                          | 0.0                              |

# 4.97 Container McuSystemOSCClockConfig

Configures System OSC registers.

Note: Implementation specific Container.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

### 4.98 Parameter McuSOSCUnderMcuControl

0 -  $\operatorname{System}$  OSC is NOT under mcu control.

1 - System OSC is under mcu control.

If this is set to false, the MCU code will not configure the SOSC registers when Mcu\_InitClock is called

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | true                             |

# 4.99 Parameter McuSOSCFrequency

This is the SOSC frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

If PLL is used, then oscillator needs to be in high range only,  $SCG\_SOSCCFG[RANGE]$  on 11 as used in reference clock.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max                          | 4.0E7                            |
| min                          | 0.0                              |

### 4.100 Parameter McuSOSCDiv2Frequency

This is the SOSC Divider 2 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 40 MHz or less in RUN/HSRUN mode.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8000000.0                        |
| max                          | 4.0E7                            |
| min                          | 0.0                              |

# 4.101 Parameter McuSOSCDiv1Frequency

This is the SOSC Divider 1 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 40 MHz or less in RUN/HSRUN mode.

| Property                     | Value                |
|------------------------------|----------------------|
| type                         | ECUC-FLOAT-PARAM-DEF |
| origin                       | NXP                  |
| symbolicNameValue            | false                |
| lowerMultiplicity            | 1                    |
| upperMultiplicity            | 1                    |
| postBuildVariantMultiplicity | N/A                  |
| multiplicityConfigClasses    | N/A                  |
| postBuildVariantValue        | true                 |

| Property           | Value                            |
|--------------------|----------------------------------|
| valueConfigClasses | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                    | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue       | 8000000.0                        |
| max                | 4.0E7                            |
| min                | 0.0                              |

### 4.102 Parameter McuSOSCEnable

 $SCG\_SOSCCSR[SOSCEN]$  - System OSC Enable

0 - System OSC is disabled.

1 -  $\operatorname{System}$  OSC is enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

# 4.103 Parameter McuSOSCClockMonitorResetEnable

 $SCG\_SOSCCSR[SOSCCMRE]$  - System OSC Clock Monitor Reset Enable

- 0 Clock Monitor generates interrupt when error detected.
- 1 Clock Monitor generates reset when error detected.

| Property | Value                  |
|----------|------------------------|
| type     | ECUC-BOOLEAN-PARAM-DEF |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.104 Parameter McuSOSCClockMonitorEnable

SCG\_SOSCCSR[SOSCCM] - System OSC Clock Monitor

Enables the clock monitor, if the clock source is disabled in a low power mode then the clock monitor is also disabled in the low power mode. When the clock monitor is disabled in a low power mode, it remains disabled until the clock valid flag is set following exit from the low power mode.

- 0 System OSC Clock Monitor is disabled.
- 1 System OSC Clock Monitor is enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.105 Parameter McuSOSCDiv2

 $Configures\ SCG\_SOSCDIV[SOSCDIV2].$ 

System OSC Clock Divide 2.

Clock divider 2 for System OSC. Used by bus clock modules that need an asynchronous clock source.

0 - Output disabled.

Note: Implementation specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 64                               |
| min                          | 0                                |

### 4.106 Parameter McuSOSCDiv1

Configures  $SCG\_SOSCDIV[SOSCDIV1]$ 

System OSC Clock Divide 1.

Clock divider 1 for System OSC. Used to generate the system clock source and by platform clock modules that need an asynchronous clock source.

0 - Output disabled.

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-INTEGER-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |
| lowerMultiplicity | 1                      |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 64                               |
| min                          | 0                                |

### 4.107 Parameter McuSOSCRangeSelect

 $SCG\_SOSCCFG[RANGE]$  - System OSC Range Select

Selects the frequency range for the system crystal oscillator (OSC)

NOTE The following constraints are not checked by the xdm schema:

If PLL is used, then oscillator needs to be in high range only,  $SCG\_SOSCCFG[RANGE]$  on 11 as used in reference clock.

- Medium frequency range selected for the crytstal oscillator of 4 MHz to 8 MHz.
- High frequency range selected for the crystal oscillator of 8 MHz to 40 MHz.

| Property                     | Value                                    |
|------------------------------|------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF               |
| origin                       | NXP                                      |
| symbolicNameValue            | false                                    |
| lowerMultiplicity            | 1                                        |
| upperMultiplicity            | 1                                        |
| postBuildVariantMultiplicity | N/A                                      |
| multiplicityConfigClasses    | N/A                                      |
| postBuildVariantValue        | true                                     |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE         |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD           |
| defaultValue                 | HIGH_FREQ_RANGE                          |
| literals                     | ['MEDIUM_FREQ_RANGE', 'HIGH_FREQ_RANGE'] |

### 4.108 Parameter McuSOSCHighGainOscillatorSelect

SCG\_SOSCCFG[HGO] - High Gain Oscillator Select

Controls the crystal oscillator power mode of operations.

unchecked - Configure crystal oscillator for low-power operation

checked - Configure crystal oscillator for high-gain operation

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.109 Parameter McuSOSCExternalReferenceSelect

SCG\_SOSCCFG[EREFS] - External Reference Select

Selects the source for the external reference clock.

unchecked - Internal oscillator of OSC requested.

checked - External reference clock from PAD pin selected

| Property                     | Value                  |
|------------------------------|------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF |
| origin                       | NXP                    |
| symbolicNameValue            | false                  |
| lowerMultiplicity            | 1                      |
| upperMultiplicity            | 1                      |
| postBuildVariantMultiplicity | N/A                    |
| multiplicityConfigClasses    | N/A                    |

| Property              | Value                            |
|-----------------------|----------------------------------|
| postBuildVariantValue | true                             |
| valueConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                       | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue          | true                             |

# 4.110 Container McuSIRCClockConfig

Configures Slow IRC (SIRC) registers.

Note: Implementation specific Container.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

### 4.111 Parameter McuSIRCUnderMcuControl

0 - Slow IRC is NOT under mcu control.

1 - Slow IRC is under mcu control.

If this is set to false, the MCU code will not configure the SIRC registers when Mcu\_InitClock is called

| Property                     | Value                  |
|------------------------------|------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF |
| origin                       | NXP                    |
| symbolicNameValue            | false                  |
| lowerMultiplicity            | 1                      |
| upperMultiplicity            | 1                      |
| postBuildVariantMultiplicity | N/A                    |
| multiplicityConfigClasses    | N/A                    |

| Property              | Value                            |
|-----------------------|----------------------------------|
| postBuildVariantValue | false                            |
| valueConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                       | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue          | false                            |

# 4.112 Parameter McuSIRCFrequency

This is the SIRC frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max                          | 8000000.0                        |
| min                          | 0.0                              |

# 4.113 Parameter McuSIRCDiv2Frequency

This is the SIRC Divider 2 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 8 MHz or less.

| Property | Value                |
|----------|----------------------|
| type     | ECUC-FLOAT-PARAM-DEF |
| origin   | NXP                  |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max                          | 8000000.0                        |
| min                          | 0.0                              |

# 4.114 Parameter McuSIRCDiv1Frequency

This is the SIRC Divider 1 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 8 MHz or less in RUN/HSRUN mode and to 4 MHz or less in VLPR mode.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max                          | 8000000.0                        |
| min                          | 0.0                              |

# 4.115 Parameter McuSIRCEnable

 $SCG\_SIRCCSR[SIRCEN]$  - Slow IRC Enable

0 - Slow IRC is disabled.

1 - Slow IRC is enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

### 4.116 Parameter McuSIRCLowPowerEnable

 ${\tt SCG\_SIRCCSR[SIRCLPEN]}$  - Slow IRC Low Power Enable

0 - Slow IRC is disabled in VLP modes.

1 - Slow IRC is enabled in VLP modes.

SCG\_SIRCCSR[SIRCLPEN] bit field is applicable for VLPS mode only.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

# 4.117 Parameter McuSIRCStopEnable

 $SCG\_SIRCCSR[SIRCSTEN]$  - Slow IRC Enable

0 - Slow IRC is disabled.

1 - Slow IRC is enabled.

SCG\_SIRCCSR[SIRCSTEN] bit field is not applicable and should be ignored.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.118 Parameter McuSIRCDiv2

 $Configures\ SCG\_SIRCDIV[SIRCDIV2].$ 

Slow IRC Clock Divider 2.

Clock divider 2 for Slow IRC. Used by bus clock modules that need an asynchronous clock source.

0 - Output disabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2                                |
| max                          | 64                               |
| min<br>ctors S32K1           | S32M24x MCU Driver               |

### 4.119 Parameter McuSIRCDiv1

 $Configures\ SCG\_SIRCDIV[SIRCDIV1].$ 

Slow IRC Clock Divider 1.

Clock divider 1 for Slow IRC. Used to generate the system clock source and by platform clock modules that need an asynchronous clock source.

0 - Output disabled.

Note: Implementation specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 64                               |
| min                          | 0                                |

# 4.120 Parameter McuSIRCRangeSelect

SCG\_SIRCCFG[RANGE] - Selects the Frequency Range

Slow IRC low range clock (2 MHz)

Slow IRC high range clock (8 MHz)

Note: The SIRC clock is chosen as source clock that must be sacrificed to be ON at all times.

Add addition, Software should not configure the SCG\_SIRCCFG[RANGE] to any value other than HIGH\_RANGE\_CLOCK.

| Property | Value                      |
|----------|----------------------------|
| type     | ECUC-ENUMERATION-PARAM-DEF |
| origin   | NXP                        |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | HIGH_RANGE_CLOCK                 |
| literals                     | ['HIGH_RANGE_CLOCK']             |

# 4.121 Container McuFIRCClockConfig

Configures Fast IRC (FIRC) registers.

Note: Implementation specific Container.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

### 4.122 Parameter McuFIRCUnderMcuControl

- 0 Fast IRC is NOT under mcu control.
- 1 Fast IRC is under mcu control.

If this is set to false, the MCU code will not configure the FIRC registers when Mcu\_InitClock is called

| Property | Value                  |
|----------|------------------------|
| type     | ECUC-BOOLEAN-PARAM-DEF |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.123 Parameter McuFIRCFrequency

This is the FIRC frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

Note: Implementation specific Container.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max                          | 4.8E7                            |
| min                          | 0.0                              |

## 4.124 Parameter McuFIRCDiv2Frequency

This is the FIRC Divider 2 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 48 MHz or less in RUN/HSRUN mode.

Note: Implementation specific Container.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2.4E7                            |
| max                          | 4.8E7                            |
| min                          | 0.0                              |

# 4.125 Parameter McuFIRCDiv1Frequency

This is the FIRC Divider 1 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 48 MHz or less in RUN/HSRUN mode.

Note: Implementation specific Container.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 4.8E7                            |
| min                          | 0.0                              |

### 4.126 Parameter McuFIRCEnable

 $SCG\_FIRCCSR[FIRCEN]$  - Fast IRC Enable

0 - Fast IRC is disabled.

1 - Fast IRC is enabled.

Note: Implementation specific Container.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

# 4.127 Parameter McuFIRCRegulatorEnable

Fast IRC Regulator Enable

0 - Fast IRC Regulator is disabled.(SCG\_FIRCCSR[FIRCREGOFF] = 1)

1 - Fast IRC Regulator is enabled.( $SCG\_FIRCCSR[FIRCREGOFF] = 0$ )

When Fast IRC is used, FIRCREGOFF must be 0. Fast IRC cannot be operated with FIRCREGOFF=1.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| default Value S32K1          | S32M24x MCU Driver NX            |

### 4.128 Parameter McuFIRCDiv2

Configures SCG\_FIRCDIV[FIRCDIV2]

Fast IRC Clock Divider 2.

Clock divider 2 for the Fast IRC. Used by bus clock modules that need an asynchronous clock source.

0 - Output disabled.

Note: Implementation specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2                                |
| max                          | 64                               |
| min                          | 0                                |

### 4.129 Parameter McuFIRCDiv1

Configures SCG\_FIRCDIV[FIRCDIV1]

Fast IRC Clock Divider 1.

Clock divider 1 for Fast IRC. Used to generate the system clock source and by platform clock modules that need an asynchronous clock source.

0 - Output disabled.

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-INTEGER-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 64                               |
| min                          | 0                                |

# 4.130 Parameter McuFIRCRangeSelect

 ${\tt SCG\_FIRCCFG[RANGE]}$  - Selects the Frequency Range.

 $00\mathrm{b}$  - Fast IRC is trimmed to 48 MHz.

01b - Reserved.

10b - Reserved.

11b - Reserved.

Note: Software should not configure the  $SCG\_FIRCCFG[RANGE]$  to any value other than Fast IRC is trimmed to 48 MHz.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | TRIMMED_TO_48MHZ                 |
| literals                     | ['TRIMMED_TO_48MHZ']             |

### 4.131 Container McuSystemPll

This container provides the specific configuration for the System PLL.

Note: Implementation Specific Container.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# 4.132 Parameter McuSystemPllUnderMcuControl

Set this to TRUE if System PLL is under mcu control

If it is FALSE then the mcu driver will not write the corresponding registers.

The user must still set the values - they are used by the clock refference points

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

## 4.133 Parameter McuSPLLFrequency

This is the System PLL frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

Note: Pll\_freq = (McuSPLLReferenceFrequency \* McuSPLLMultiplier)/2

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max                          | 1.6E8                            |
| min                          | 0.0                              |

# 4.134 Parameter McuSPLLDiv2Frequency

This is the System PLL Divider 2 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 40 MHz or less in RUN mode and 56 MHz or less in HSRUN mode.

| Property                     | Value                |
|------------------------------|----------------------|
| type                         | ECUC-FLOAT-PARAM-DEF |
| origin                       | NXP                  |
| symbolicNameValue            | false                |
| lowerMultiplicity            | 1                    |
| upperMultiplicity            | 1                    |
| postBuildVariantMultiplicity | N/A                  |
| multiplicityConfigClasses    | N/A                  |
| postBuildVariantValue        | true                 |

| Property           | Value                            |
|--------------------|----------------------------------|
| valueConfigClasses | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                    | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue       | 2.4E7                            |
| max                | 4.0E7                            |
| min                | 0.0                              |

# 4.135 Parameter McuSPLLDiv1Frequency

This is the System PLL Divider 1 frequency for the specific instance of the

McuClockReferencePoint container. It is expressed in Hz.

This should be configured to 80MHz or less in RUN mode and to 112 MHz or less in HSRUN mode.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 8.0E7                            |
| min                          | 0.0                              |

### 4.136 Parameter McuSPLLEnable

 $SCG\_SPLLCSR[SPLLEN]$  - System PLL Enable

0 - System PLL is disabled.

1 - System PLL is enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.137 Parameter McuSPLLClockMonitorResetEnable

 ${\tt SCG\_SPLLCSR[SPLLCMRE]}$  -  ${\tt System\ PLL\ Clock\ Monitor\ Reset\ Enable}$ 

- 0 Clock Monitor generates interrupt when error detected.
- 1 Clock Monitor generates reset when error detected.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.138 Parameter McuSPLLClockMonitorEnable

 $SCG\_SPLLCSR[SPLLCM]$  - System PLL Clock Monitor

Enables the clock monitor, if the clock source is disabled in a low power mode then the clock monitor is

also disabled in the low power mode. When the clock monitor is disabled in a low power mode, it remains disabled until the clock valid flag is set following exit from the low power mode.

0 - RTC OSC Clock Monitor is disabled.

1 - RTC OSC Clock Monitor is enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.139 Parameter McuSPLLDiv2

Configures SCG\_SPLLDIV[SPLLDIV2].

System PLL Clock Divider 2.

Clock divider 2 for System PLL. Used by bus clock modules that need an asynchronous clock source.

0 - Output disabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue S32K1           | S32M24x MCU Driver               |
| max                          | 64                               |
| min                          | 0                                |

### 4.140 Parameter McuSPLLDiv1

Configures SCG\_SPLLDIV[SPLLDIV1]

System PLL Clock Divider 1.

Clock divider 1 for System PLL. Used to generate the system clock source and by platform clock modules that need an asynchronous clock source.

0 - Output disabled.

Note: Implementation specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 2                                |
| max                          | 64                               |
| min                          | 0                                |

# 4.141 Parameter McuSPLLInputClkPreDivider

PLL Reference Clock Divider.

Set the SPLL: SCG\_SPLLCFG[PREDIV] field register.

Selects the amount to divide down the reference clock for the System PLL. The resulting frequency must be in the range of  $8~\mathrm{MHz}$  to  $50~\mathrm{MHz}$ .

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-INTEGER-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |
| lowerMultiplicity | 1                      |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 8                                |
| min                          | 1                                |

# 4.142 Parameter McuSPLLReferenceFrequency

FSPLL\_REF is PLL reference frequency range after the PREDIV.

 $\label{eq:final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_final_$ 

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8000000.0                        |
| max                          | 1.6E7                            |
| min                          | 0.0                              |

# 4.143 Parameter McuSPLLInputFrequency

FSPLL\_Input is PLL input frequency range before the PREDIV.

For S32K1XX, the valid range is [0 ... 40] MHz.

For S32R14xW, the valid range is  $[0 \dots 48]$  MHz.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8000000.0                        |
| max                          | 4.8E7                            |
| min                          | 0.0                              |

# 4.144 Parameter McuSPLLMultiplier

System PLL Multiplier.

Set the  $SCG\_SPLLCFG[MULT]$  field register.

Valid range is in [16..47].

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 20                               |
| max                          | 47                               |
| min                          | 16                               |

100

## 4.145 Parameter McuSPLLSelectSourceClock

SPLLCFG[SOURCE]: System PLL Clock Source.

Configures the input clock source for the System PLL.

The selected clock must be enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | SOSC_CLK                         |
| literals                     | ['SOSC_CLK', 'FIRC_CLK']         |

# 4.146 Container McuSIMClockConfig

Configures SIM\_CHIPCTL[TRACECLK\_SEL], SIM\_CHIPCTL[CLKOUTSEL] bits and SIM\_PLATGC and SIM\_CLKDIV4 registers.

Note: Implementation specific Container.

Included subcontainers:

- McuSimChipConfiguration
- McuSimLpoConfiguration
- $\bullet \ \ McuSimFtmConfiguration$

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.147 Parameter McuSIMUnderMcuControl

0 - SIM is NOT under mcu control.

1 - SIM is under mcu control.

If this is set to false, the MCU code will not configure the SIM registers when Mcu\_InitClock is called

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# ${\bf 4.148}\quad {\bf Parameter}\ {\bf McuEIMClockGatingEnable}$

 $SIM\_PLATCGC[CGCEIM]$  - EIM Clock Gating Control

Controls the clock gating to the EIM.

0 - Clock disabled.

1 - Clock enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolic} Name Value$  | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
| <u> </u>                     | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue S32K1           | S32M24x MCU Driver NX            |

# 4.149 Parameter McuERMClockGatingEnable

 $SIM\_PLATCGC[CGCERM]$  - ERM Clock Gating Control

Controls the clock gating to the ERM.

0 - Clock disabled.

1 - Clock enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

# ${\bf 4.150 \quad Parameter \ McuDMAClockGatingEnable}$

SIM\_PLATCGC[CGCDMA] - DMA Clock Gating Control

Controls the clock gating to the DMA module.

0 - Clock disabled.

1 - Clock enabled.

| Property                     | Value                  |
|------------------------------|------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF |
| origin                       | NXP                    |
| symbolicNameValue            | false                  |
| lowerMultiplicity            | 1                      |
| upperMultiplicity            | 1                      |
| postBuildVariantMultiplicity | N/A                    |
| multiplicityConfigClasses    | N/A                    |

#### Tresos Configuration Plug-in

| Property              | Value                            |
|-----------------------|----------------------------------|
| postBuildVariantValue | true                             |
| valueConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                       | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue          | true                             |

## 4.151 Parameter McuMPUClockGatingEnable

SIM\_PLATCGC[CGCMPU] - MPU Clock Gating Control

Controls the clock gating to the MPU module.

0 - Clock disabled.

1 - Clock enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

## 4.152 Parameter McuMSCMClockGatingEnable

 $\operatorname{SIM}\_\operatorname{PLATCGC}[\operatorname{CGCMSCM}]$  -  $\operatorname{MSCM}$  Clock Gating Control

Controls the clock gating to the MSCM module.

0 - Clock disabled.

1 - Clock enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

## 4.153 Parameter McuGPIOClockGatingEnable

 $\operatorname{SIM\_PLATCGC}[\operatorname{CGCGPIO}]$  - GPIO Clock Gating Control

Controls the clock gating to the GPIO module.

0 - Clock disabled.

1 - Clock enabled.

Note: Implementation Specific Parameter. This bit is available in S32K11X variants only

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.154 Container McuSimChipConfiguration

This container contains the configuration for the SIM\_CHIPCTL registers.

Included subcontainers:

#### Tresos Configuration Plug-in

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.155 Parameter McuDebugTraceDividerEnable

 $SIM\_CLKDIV4[TRACEDIVEN]$  - Debug Trace Divider Control

- 0 Debug trace divider disabled.
- 1 Debug trace divider enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

#### 4.156 Parameter McuTRACECLKDivider

Configures the  $SIM\_CLKDIV4[TRACEDIV]$  bitfield

Trace clock divider divisor - This field sets the divide value for the fractional clock divider used as a source for trace clock. The source clock for the trace clock is set by the SIM\_CHIPCTRL[TRACECLK\_SEL]. Divider output clock = Divider input clock \* [(TRACEFRAC+1)/(TRACEDIV+1)].

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 8                                |
| min                          | 1                                |

#### 4.157 Parameter McuTRACECLKFraction

Configures the SIM\_CLKDIV4[TRACEFRAC] bitfield

This field value is TRACEFRAC+1.

Trace clock divider fraction - This field sets the divide value for the fractional clock divider used as a source for trace clock. The source clock for the trace clock is set by the SIM\_CHIPCTRL[TRACECLK\_SEL]. Divider output clock = Divider input clock \* [(TRACEFRAC+1)/(TRACEDIV+1)].

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolic} Name Value$  | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
| valueConnigClasses           | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 2                                |
| min                          | 1                                |

#### 4.158 Parameter McuTRACECLKSelect

 $\operatorname{SIM\_CHIPCTL}[\operatorname{TRACECLK\_SEL}]$  - Debug trace clock select

Selects core clock or platform clock as the trace clock source.

The selected clock must be enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | CORE_CLK                         |
| literals                     | ['CORE_CLK']                     |

#### 4.159 Parameter McuCLKOUTEnable

 $SIM\_CHIPCTL[CLKOUTEN]$  - CLKOUT enable

unchecked - Clockout disabled.

checked - Clockout enabled.

Maximum supported clock out frequency for this device is 20 MHz.

Note: Implementation Specific Parameter.

| Property                     | Value                                                                                        |             |
|------------------------------|----------------------------------------------------------------------------------------------|-------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF                                                                       |             |
| origin                       | NXP                                                                                          |             |
| symbolicNameValue            | false                                                                                        |             |
| lowerMultiplicity            | 1                                                                                            |             |
| upperMultiplicity            | 1                                                                                            |             |
| postBuildVariantMultiplicity | N/A                                                                                          |             |
| multiplicityConfigClasses    | N/A                                                                                          |             |
| postBuildVariantValue        | true                                                                                         |             |
| valueConfigClasses S32K1     | VARIANT-PRE-COMPILE: PRE-COMPILE<br>S32M24x MCU Driver NXI<br>VARIANT-POST-BUILD: POST-BUILD | P Semicondu |
| defaultValue                 | false                                                                                        |             |

108

#### 4.160 Parameter McuCLKOUTDivider

Configures the SIM\_CHIPCTL[CLKOUTDIV] bitfield

CLKOUT Divide Ratio.

Note: implementation specific parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 8                                |
| min                          | 1                                |

#### 4.161 Parameter McuCLKOUTSelect

 $SIM\_CHIPCTL[CLKOUTSEL]$  - CLKOUT select

Selects the clock to output on the CLKOUT pin.

- 0 SCG\_CLKOUT
- 2 SOSC\_DIV2
- $4 \text{ SIRC\_DIV2}$
- 5 For S32K148: QSPI\_SFIF\_CLK\_HYP\_PREMUX\_CLK: Divide by 2 clock (configured through SCLKCON-FIG[5]) for HyperRAM going to sfif clock to QSPI; For others: Reserved
- $6 ext{ FIRC\_DIV2}$
- 7 HCLK
- 8 For S32K14x: SPLL\_DIV2\_CLK For S32K11x: Reserved
- 9 BUS\_CLK
- A LPO\_128K\_CLK

#### Tresos Configuration Plug-in

B For S32K148: QSPI\_CLK; For others: Reserved

C LPO\_CLK as selected by SIM\_LPOCLKS[LPOCLKSEL]

D For S32K148: QSPI\_SFIF\_CLK; For others: Reserved

E RTC\_CLK as selected by SIM CLK 32 KHz Select

F For S32K148: QSPI\_2xSFIF\_CLK; For others: Reserved

The selected clock must be enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                                                                                                                                                 |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                                                                                                            |
| origin                       | NXP                                                                                                                                                   |
| ${\it symbolicNameValue}$    | false                                                                                                                                                 |
| lowerMultiplicity            | 1                                                                                                                                                     |
| upperMultiplicity            | 1                                                                                                                                                     |
| postBuildVariantMultiplicity | N/A                                                                                                                                                   |
| multiplicityConfigClasses    | N/A                                                                                                                                                   |
| postBuildVariantValue        | true                                                                                                                                                  |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                                                                                                                      |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                                                                                                                        |
| defaultValue                 | SCG_CLKOUT_CLK                                                                                                                                        |
| literals                     | ['SCG_CLKOUT_CLK', 'SOSCDIV2_CLK', 'SIRCDIV2_CLK', 'FIRCDIV2←<br>_CLK', 'HCLK', 'SPLLDIV2_CLK', 'BUS_CLK', 'LPO_128K_CLK', 'LPO←<br>_CLK', 'RTC_CLK'] |

# 4.162 Container McuSimLpoConfiguration

This container contains the configuration for the SIM\_LPOCLKS registers.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

#### 4.163 Parameter McuRTCClkSelect

This is a write-once parameter

SIM\_LPOCLKS[RTCCLKSEL] - 32 kHz clock source select.

Selects 32 kHz clock source for peripherals.

- $0 SOSCDIV1\_CLK$
- 1 32 kHz LPO clock
- 2 32 kHz RTC\_CLKIN clock
- 3 FIRCDIV1\_CLK

Note: Implementation Specific Parameter.

| Property                     | Value                                                        |
|------------------------------|--------------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                   |
| origin                       | NXP                                                          |
| symbolicNameValue            | false                                                        |
| lowerMultiplicity            | 1                                                            |
| upperMultiplicity            | 1                                                            |
| postBuildVariantMultiplicity | N/A                                                          |
| multiplicityConfigClasses    | N/A                                                          |
| postBuildVariantValue        | true                                                         |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                             |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                               |
| defaultValue                 | SOSCDIV1_CLK                                                 |
| literals                     | ['SOSCDIV1_CLK', 'LPO_32K_CLK', 'RTC_CLKIN', 'FIRCDIV1_CLK'] |

## 4.164 Parameter McuLPOClkSelect

This is a write-once parameter

 $\operatorname{SIM\_LPOCLKS[LPOCLKSEL]}$  - LPO clock source select

Selects LPO clock source for peripherals

- 0 128 kHz LPO clock
- 1 No clock
- 2  $32~\mathrm{kHz}$  LPO clock which is divided by the  $128~\mathrm{kHz}$  LPO clock
- 3  $1~\mathrm{kHz}$  LPO clock which is divided by the 128 kHz LPO clock

#### Tresos Configuration Plug-in

| Property                     | Value                                                     |
|------------------------------|-----------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                |
| origin                       | NXP                                                       |
| symbolicNameValue            | false                                                     |
| lowerMultiplicity            | 1                                                         |
| upperMultiplicity            | 1                                                         |
| postBuildVariantMultiplicity | N/A                                                       |
| multiplicityConfigClasses    | N/A                                                       |
| postBuildVariantValue        | true                                                      |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                          |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                            |
| defaultValue                 | LPO_128K_CLK                                              |
| literals                     | ['LPO_128K_CLK', 'NO_CLOCK', 'LPO_32K_CLK', 'LPO_1K_CLK'] |

## 4.165 Parameter McuLPO\_32KClockEnable

This is a write-once parameter

 $SIM\_LPOCLKS[LPO32KCLKEN]$  - 32 kHz LPO clock enable

0 - Disable 32 kHz LPO clock output

1 - Enable 32 kHz LPO clock output

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

# 4.166 Parameter McuLPO\_1KClockEnable

This is a write-once parameter

#### $\operatorname{SIM\_LPOCLKS}[\operatorname{LPO1KCLKEN}]$ - 1 kHz LPO clock enable

0 - Disable 1 kHz LPO clock output

1 - Enable 1 kHz LPO clock output

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

## 4.167 Container McuSimFtmConfiguration

This container contains the configuration for the SIM\_FTMOPT0 registers.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

#### 4.168 Parameter McuFTM3ExternalClockPinSelect

 ${\rm SIM\_FTMOPT0[FTM3CLKSEL] - FTM3 \ External \ Clock \ Pin \ Select}$ 

Selects the external pin used to drive the clock to the FTM3 module.

#### Tresos Configuration Plug-in

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM3 external clock driven by TCLK0 pin.
- 1 FTM3 external clock driven by TCLK1 pin.
- 2 FTM3 external clock driven by TCLK2 pin.
- 3 No clock input.

Note: Implementation Specific Parameter.

| Property                     | Value                                               |
|------------------------------|-----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                          |
| origin                       | NXP                                                 |
| symbolicNameValue            | false                                               |
| lowerMultiplicity            | 1                                                   |
| upperMultiplicity            | 1                                                   |
| postBuildVariantMultiplicity | N/A                                                 |
| multiplicityConfigClasses    | N/A                                                 |
| postBuildVariantValue        | true                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                    |
|                              | VARIANT-POST-BUILD: POST-BUILD                      |
| defaultValue                 | TCLK0_PIN                                           |
| literals                     | ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |

#### 4.169 Parameter McuFTM2ExternalClockPinSelect

SIM\_FTMOPT0[FTM2CLKSEL] - FTM2 External Clock Pin Select

Selects the external pin used to drive the clock to the FTM2 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM2 external clock driven by TCLK0 pin.
- 1 FTM2 external clock driven by TCLK1 pin.
- 2 FTM2 external clock driven by TCLK2 pin.
- 3 No clock input.

| Property                     | Value                                               |
|------------------------------|-----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                          |
| origin                       | NXP                                                 |
| symbolicNameValue            | false                                               |
| lowerMultiplicity            | 1                                                   |
| upperMultiplicity            | 1                                                   |
| postBuildVariantMultiplicity | N/A                                                 |
| multiplicityConfigClasses    | N/A                                                 |
| postBuildVariantValue        | true                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                    |
|                              | VARIANT-POST-BUILD: POST-BUILD                      |
| defaultValue                 | TCLK0_PIN                                           |
| literals                     | ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |

#### 4.170 Parameter McuFTM1ExternalClockPinSelect

 $\operatorname{SIM\_FTMOPT0}[\operatorname{FTM1CLKSEL}]$  - FTM1 External Clock Pin Select

Selects the external pin used to drive the clock to the FTM1 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM1 external clock driven by TCLK0 pin.
- 1 FTM1 external clock driven by TCLK1 pin.
- 2 FTM1 external clock driven by TCLK2 pin.
- 3 No clock input.

| Value                                               |
|-----------------------------------------------------|
| ECUC-ENUMERATION-PARAM-DEF                          |
| NXP                                                 |
| false                                               |
| 1                                                   |
| 1                                                   |
| N/A                                                 |
| N/A                                                 |
| true                                                |
| VARIANT-PRE-COMPILE: PRE-COMPILE                    |
| VARIANT-POST-BUILD: POST-BUILD                      |
| TCLK0_PIN                                           |
| ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |
|                                                     |

#### 4.171 Parameter McuFTM0ExternalClockPinSelect

SIM\_FTMOPT0[FTM0CLKSEL] - FTM0 External Clock Pin Select

Selects the external pin used to drive the clock to the FTM0 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM0 external clock driven by TCLK0 pin.
- 1 FTM0 external clock driven by TCLK1 pin.
- 2 FTM0 external clock driven by TCLK2 pin.
- 3 No clock input.

Note: Implementation Specific Parameter.

| Property                     | Value                                               |
|------------------------------|-----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                          |
| origin                       | NXP                                                 |
| symbolicNameValue            | false                                               |
| lowerMultiplicity            | 1                                                   |
| upperMultiplicity            | 1                                                   |
| postBuildVariantMultiplicity | N/A                                                 |
| multiplicityConfigClasses    | N/A                                                 |
| postBuildVariantValue        | true                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                    |
|                              | VARIANT-POST-BUILD: POST-BUILD                      |
| defaultValue                 | TCLK0_PIN                                           |
| literals                     | ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |

#### 4.172 Parameter McuFTM7ExternalClockPinSelect

SIM\_FTMOPT0[FTM7CLKSEL] - FTM7 External Clock Pin Select

Selects the external pin used to drive the clock to the FTM7 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM7 external clock driven by TCLK0 pin.
- 1 FTM7 external clock driven by TCLK1 pin.
- 2 FTM7 external clock driven by TCLK2 pin.
- 3 No clock input.

| Property                     | Value                                               |
|------------------------------|-----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                          |
| origin                       | NXP                                                 |
| symbolicNameValue            | false                                               |
| lowerMultiplicity            | 1                                                   |
| upperMultiplicity            | 1                                                   |
| postBuildVariantMultiplicity | N/A                                                 |
| multiplicityConfigClasses    | N/A                                                 |
| postBuildVariantValue        | true                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                    |
|                              | VARIANT-POST-BUILD: POST-BUILD                      |
| defaultValue                 | TCLK0_PIN                                           |
| literals                     | ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |

#### 4.173 Parameter McuFTM6ExternalClockPinSelect

 $\operatorname{SIM\_FTMOPT0}[\operatorname{FTM6CLKSEL}]$  -  $\operatorname{FTM6}$  External Clock Pin Select

Selects the external pin used to drive the clock to the FTM6 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM6 external clock driven by TCLK0 pin.
- 1 FTM6 external clock driven by TCLK1 pin.
- 2 FTM6 external clock driven by TCLK2 pin.
- 3 No clock input.

| Value                                               |
|-----------------------------------------------------|
| ECUC-ENUMERATION-PARAM-DEF                          |
| NXP                                                 |
| false                                               |
| 1                                                   |
| 1                                                   |
| N/A                                                 |
| N/A                                                 |
| true                                                |
| VARIANT-PRE-COMPILE: PRE-COMPILE                    |
| VARIANT-POST-BUILD: POST-BUILD                      |
| TCLK0_PIN                                           |
| ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |
|                                                     |

#### 4.174 Parameter McuFTM5ExternalClockPinSelect

SIM\_FTMOPT0[FTM5CLKSEL] - FTM5 External Clock Pin Select

Selects the external pin used to drive the clock to the FTM5 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM5 external clock driven by TCLK0 pin.
- 1 FTM5 external clock driven by TCLK1 pin.
- 2 FTM5 external clock driven by TCLK2 pin.
- 3 No clock input.

Note: Implementation Specific Parameter.

| Property                     | Value                                               |
|------------------------------|-----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                          |
| origin                       | NXP                                                 |
| symbolicNameValue            | false                                               |
| lowerMultiplicity            | 1                                                   |
| upperMultiplicity            | 1                                                   |
| postBuildVariantMultiplicity | N/A                                                 |
| multiplicityConfigClasses    | N/A                                                 |
| postBuildVariantValue        | true                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                    |
|                              | VARIANT-POST-BUILD: POST-BUILD                      |
| defaultValue                 | TCLK0_PIN                                           |
| literals                     | ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |

#### 4.175 Parameter McuFTM4ExternalClockPinSelect

SIM\_FTMOPT0[FTM7CLKSEL] - FTM4 External Clock Pin Select

Selects the external pin used to drive the clock to the FTM4 module.

The selected pin must also be configured for the FTM external clock function through the appropriate Pin Control Register in the Port Control module.

- 0 FTM4 external clock driven by TCLK0 pin.
- 1 FTM4 external clock driven by TCLK1 pin.
- 2 FTM4 external clock driven by TCLK2 pin.
- 3 No clock input.

| Property                     | Value                                               |
|------------------------------|-----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                          |
| origin                       | NXP                                                 |
| symbolicNameValue            | false                                               |
| lowerMultiplicity            | 1                                                   |
| upperMultiplicity            | 1                                                   |
| postBuildVariantMultiplicity | N/A                                                 |
| multiplicityConfigClasses    | N/A                                                 |
| postBuildVariantValue        | true                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                    |
|                              | VARIANT-POST-BUILD: POST-BUILD                      |
| defaultValue                 | TCLK0_PIN                                           |
| literals                     | ['TCLK0_PIN', 'TCLK1_PIN', 'TCLK2_PIN', 'NO_CLOCK'] |

#### 4.176 Container McuClkMonitor

This container contains the specific configuration (parameters) of the Clock Monitor Unit.

Each CMU is independently programmed. SIRC is used as the clock monitor references.

Detailed information on the CMUs can be found in the Clock Monitor Unit chapter.

This parameter is enabled only if "McuClockSrcFailureNotification" is enabled.

This container only for S32K11x derivatives.

Note: Implementation Specific Parameter.

Included subcontainers:

- McuClkMonitor\_0
- McuClkMonitor\_1

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

#### 4.177 Container McuClkMonitor\_0

This container contains the specific configuration (parameters) of the Monitor\_0.

Clock Monitor Unit for Motor Clock.

This parameter is enabled only if "McuClockSrcFailureNotification" is enabled.

Note: Implementation Specific Parameter.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.178 Parameter McuClockMonitorUnderMcuControl

Set this to TRUE if this clock monitor is under mcu control

If it is FALSE then the mcu driver will not write the corresponding registers.

The user must still set the values - they are used by the clock reference points

This container only for S32K11x derivatives.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.179 Parameter McuClkMonitorEn

Enables/Disables the clock monitor (CMU\_FC\_GCR[FCE]).

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

#### 4.180 Parameter McuCmuName

This is the name of the CMU0.

With name convention: CMU\_FC\_[Number Of CMU Unit]\_[Name of Monitored clock].

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | CMU_FC_0_FIRC_MON1_CLK           |
| literals                     | ['CMU_FC_0_FIRC_MON1_CLK']       |

## 4.181 Parameter McuAsyncFHHInterruptEn

This field is used to enable/disable FHH asynchronous interrupt at the module boundary. (CMU\_FC\_IER[FHHAIE]).

0 - Asynchronous FHH Interrupt is Disabled

1 - Asynchronous FHH Interrupt is Enabled

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.182 Parameter McuAsyncFLLInterruptEn

This field is used to enable/disable FLL asynchronous interrupt at the module boundary. (CMU\_FC\_IER[FLLAIE]).

0 - Asynchronous FLL Interrupt is Disabled

1 - Asynchronous FLL Interrupt is Enabled

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.183 Container McuClkMonitor\_1

This container contains the specific configuration (parameters) of the Monitor\_1.

Clock Monitor Unit for Motor Clock.

This parameter is enabled only if "McuClockSrcFailureNotification" is enabled.

Note: Implementation Specific Parameter.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.184 Parameter McuClockMonitorUnderMcuControl

Set this to TRUE if this clock monitor is under mcu control

If it is FALSE then the mcu driver will not write the corresponding registers.

The user must still set the values - they are used by the clock reference points

This container only for S32K11x derivatives.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.185 Parameter McuClkMonitorEn

Enables/Disables the clock monitor (CMU\_FC\_GCR[FCE]).

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.186 Parameter McuCmuName

This is the name of the CMU1.

With name convention: CMU\_FC\_[Number Of CMU Unit]\_[Name of Monitored clock].

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | CMU_FC_1_FIRC_MON2_CLK           |
| literals                     | ['CMU_FC_1_FIRC_MON2_CLK']       |

## 4.187 Parameter McuSyncFHHInterruptEn

This field is used to enable/disable FHH synchronous interrupt at the module boundary. (CMU\_FC\_IER[FHHIE]).

0 - Synchronous FHH Interrupt is Disabled

1 - Synchronous FHH Interrupt is Enabled

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.188 Parameter McuSyncFLLInterruptEn

This field is used to enable/disable FLL synchronous interrupt at the module boundary. (CMU\_FC\_IER[FLLIE]).

0 - Synchronous FLL Interrupt is Disabled

1 - Synchronous FLL Interrupt is Enabled

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.189 Container McuPeripheralClockConfig

This contains the combination for current peripheral in Run and LowPower Mode.

Note: Implementation Specific Container.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 30                            |
| upperMultiplicity            | 30                            |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# ${\bf 4.190} \quad {\bf Parameter} \ {\bf McuPeripheral Clock Under McuControl}$

- 0 Peripheral Clock is NOT under mcu control.
- 1 Peripheral Clock is under mcu control.

If this is set to false, the MCU code will not configure the PCC registers when Mcu\_InitClock is called

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | true                             |

## 4.191 Parameter McuPerName

This is the name of the peripheral.

Note: Implementation Specific Parameter.

| Property                     | Value                                                                         |
|------------------------------|-------------------------------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                                    |
| origin                       | NXP                                                                           |
| symbolicNameValue            | false                                                                         |
| lowerMultiplicity            | 1                                                                             |
| upperMultiplicity            | 1                                                                             |
| postBuildVariantMultiplicity | N/A                                                                           |
| multiplicityConfigClasses    | N/A                                                                           |
| postBuildVariantValue        | false                                                                         |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                                              |
| varueComigClasses            | VARIANT-POST-BUILD: PRE-COMPILE                                               |
| defaultValue                 | FTFM                                                                          |
| literals                     | ['FTFM', 'DMAMUX0', 'FLEXCAN0', 'FLEXCAN1', 'FTM3', 'ADC1', 'LPS $\leftarrow$ |
|                              | PIO', 'LPSPI1', 'LPSPI2', 'PDB1', 'CRC0', 'PDB0', 'LPIT0', 'FTM0', 'FTM1',    |
|                              | 'FTM2', 'ADC0', 'RTC0', 'LPTMR0', 'PORTA', 'PORTB', 'PORTC', 'PORTD',         |
|                              | 'PORTE', 'FlexIO', 'EWM0', 'LPI2C0', 'LPUART0', 'LPUART1', 'CMP0']            |

## 4.192 Parameter McuPeripheralClockEnable

Sets PCC\_[peripheral][CGC] bit.

This read/write bit enables the clock for the peripheral.

0 - Clock disabled.

1 - Clock enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                                                |
|------------------------------|------------------------------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF                               |
| origin                       | NXP                                                  |
| symbolicNameValue            | false                                                |
| lowerMultiplicity            | 1                                                    |
| upperMultiplicity            | 1                                                    |
| postBuildVariantMultiplicity | N/A                                                  |
| multiplicityConfigClasses    | N/A                                                  |
| postBuildVariantValue        | true                                                 |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                     |
| C22V1                        | VARIANT-POST-BUILD: POST-BUILD<br>S32M24x MCU Driver |
| default Value S32K 1         | true                                                 |

NXP Semicondu

## 4.193 Parameter McuPeripheralClockSelect

Configures PCC\_[peripheral][PCS].

This is used for peripherals that support various clock selections.

If the peripheral does not support various clock selections the field won't be editable.

This field can only be written when the CGC bit is 0 (clock disabled). Likewise, if the INUSE flag is set, this field is locked.

- 0 Clock is off (or external clock as selected by FTMnCLKSEL for FTM modules).
- 1 SOSCDIV2\_CLK (SOCDIV1\_CLK for FTM modules)
- 2 SIRCDIV2\_CLK (SIRCDIV1\_CLK for FTM modules)
- 3 FIRCDIV2\_CLK (FIRCDIV1\_CLK for FTM modules)
- 6 SPLLDIV2\_CLK (SPLLDIV1\_CLK for FTM modules)

The selected clock must be enabled.

Note: Please make sure that the divider of clock source is not 0.

If the field is not editable, it means the bit field is read only and the value will not be used.

Note: Implementation Specific Parameter.

| Property                     | Value                                                            |
|------------------------------|------------------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                       |
| origin                       | NXP                                                              |
| symbolicNameValue            | false                                                            |
| lowerMultiplicity            | 1                                                                |
| upperMultiplicity            | 1                                                                |
| postBuildVariantMultiplicity | N/A                                                              |
| multiplicityConfigClasses    | N/A                                                              |
| postBuildVariantValue        | true                                                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                                 |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                                   |
| defaultValue                 | CLOCK_IS_OFF                                                     |
| literals                     | ['CLOCK_IS_OFF', 'SOSC', 'SIRC', 'FIRC', 'SPLL', 'LPO_128K_CLK'] |

## 4.194 Parameter McuPeripheralClockDivider

Configures PCC\_[peripheral][PCD].

This is used for peripherals that require a clock divider. At SOC integration, each peripheral is assigned either a divider or not.

This field can only be written when the CGC bit is 0 (clock disabled). Likewise, if the INUSE flag is set, this field is locked.

Allowed values are from 1 to 8.

Note: Implementation Specific Parameter.

If the field is not editable, it means the bit field is read only and the value will not be used.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 8                                |
| min                          | 1                                |

## 4.195 Parameter McuPeripheralFractionalDivider

Configures PCC\_[peripheral][FRAC].

This field value is FRAC+1.

This sets the fraction multiply value for the fractional clock divider used as a clock source. Divider output clock = Divider input clock x [(FRAC+1)/(DIV+1)].

This field can only be written when the CGC bit is 0 (clock disabled). Likewise, if the INUSE flag is set, this field is locked.

- 1 Fractional Multiply value is 1.
- 2 Fractional Multiply value is 2.

Note: Implementation Specific Parameter.

If the field is not editable, it means the bit field is read only and the value will not be used.

#### Tresos Configuration Plug-in

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1                                |
| max                          | 2                                |
| min                          | 1                                |

## 4.196 Parameter McuPeripheralClockFrequency

Divider output clock = Divider input clock x [(FRAC+1)/(DIV+1)].

This is only calculated if the clock source is selectable and if the peripheral is enabled.

This is the frequency for the specific instance of the "McuClockReferencePoint" container.

Value calculated for user info. It is given in Hz.

Note: The maximum frequency of LPUARTx, LPSPIx, LPI2Cx, FlexIO, LPTMR0 and LPIT0 are governed by BUS\_CLK,

FTMx are governed by SYS\_CLK, ADCx are 50MHz but always less than BUS\_CLK.

So please check configuration value is fit for SYS\_CLK and BUS\_CLK values correspond to MCU mode.

Note: Implementation Specific Parameter.

min

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0.0                              |
| max <b>S32K1</b> _           | S32M24x MCU Driver NX            |

0.0

#### 4.197 Container McuClockReferencePoint

This container defines a reference point in the Mcu Clock tree. It defines the frequency which then can be used by other modules as an input value. Lower multiplicity is 1, as even in the simpliest case (only one frequency is used), there is one frequency to be defined.

Included subcontainers:

#### • None

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF    |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | Infinite                         |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |

# 4.198 Parameter McuClockReferencePointFrequency

This is the frequency for the specific instance of the McuClockReferencePoint container.

It shall be given in Hz.

Calculated value.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-FLOAT-PARAM-DEF             |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 4.8E7                            |
| max                          | 3.2E8                            |
| min                          | 0.0                              |

## 4.199 Parameter McuClockFrequencySelect

Select clock source for the specific instance of the McuClockReferencePoint container.

Note: The clock frequency configured in McuPeripheralClockConfig should be used to export the clock frequency through McuClockReferencePoint.

This reference point should be used in the configuration of the module that uses it (SPI, I2C, GPT, etc.).

If the configured module has also an internal clock selection (like FlexTimer for example),

the clock reference point should be configured taking the internal clock selection into account and the reference used should reflect the clock that finally enters the used peripheral.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| ${\it symbolic} Name Value$  | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | RUN_SYS_CLK                      |
| literals                     |                                  |

#### 4.200 Container McuDemEventParameterRefs

Container for the references to DemEventParameter elements which shall be invoked using the API Dem\_ReportErrorStatus API in case the corresponding error occurs.

The EventId is taken from the referenced DemEventParameter's DemEventId value.

The standardized errors are provided in the container and can be extended by vendor specific error references. Included subcontainers:

• None

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF    |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |

## 4.201 Reference MCU\_E\_TIMEOUT\_FAILURE

Reference to configured DEM event to report Timeout failure.

| Property                             | Value                                                |
|--------------------------------------|------------------------------------------------------|
| type                                 | ECUC-REFERENCE-DEF                                   |
| origin                               | NXP                                                  |
| lowerMultiplicity                    | 0                                                    |
| upperMultiplicity                    | 1                                                    |
| postBuildVariantMultiplicity         | false                                                |
| multiplicityConfigClasses            | VARIANT-POST-BUILD: PRE-COMPILE                      |
|                                      | VARIANT-PRE-COMPILE: PRE-COMPILE                     |
| postBuildVariantValue                | false                                                |
| valueConfigClasses                   | VARIANT-POST-BUILD: PRE-COMPILE                      |
|                                      | VARIANT-PRE-COMPILE: PRE-COMPILE                     |
| ${\it requires Symbolic Name Value}$ | true                                                 |
| destination                          | /AUTOSAR/EcucDefs/Dem/DemConfigSet/DemEventParameter |

## 4.202 Reference MCU\_E\_CLOCK\_FAILURE

Reference to configured DEM event to report Clock source failure.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-REFERENCE-DEF               |
| origin                       | AUTOSAR_ECUC                     |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-POST-BUILD: PRE-COMPILE  |
|                              | VARIANT-PRE-COMPILE: PRE-COMPILE |

#### Tresos Configuration Plug-in

| Property                             | Value                                                |
|--------------------------------------|------------------------------------------------------|
| ${\it requires Symbolic Name Value}$ | False                                                |
| destination                          | /AUTOSAR/EcucDefs/Dem/DemConfigSet/DemEventParameter |

# ${\bf 4.203}\quad {\bf Reference\ MCU\_E\_SWITCHMODE\_FAILURE}$

Reference to configured DEM event to report Switch Mode failure.

| Property                             | Value                                                |
|--------------------------------------|------------------------------------------------------|
| type                                 | ECUC-REFERENCE-DEF                                   |
| origin                               | NXP                                                  |
| lowerMultiplicity                    | 0                                                    |
| upperMultiplicity                    | 1                                                    |
| postBuildVariantMultiplicity         | false                                                |
| multiplicityConfigClasses            | VARIANT-POST-BUILD: PRE-COMPILE                      |
|                                      | VARIANT-PRE-COMPILE: PRE-COMPILE                     |
| postBuildVariantValue                | false                                                |
| valueConfigClasses                   | VARIANT-POST-BUILD: PRE-COMPILE                      |
|                                      | VARIANT-PRE-COMPILE: PRE-COMPILE                     |
| ${\it requires Symbolic Name Value}$ | true                                                 |
| destination                          | /AUTOSAR/EcucDefs/Dem/DemConfigSet/DemEventParameter |

# 4.204 Container McuModeSettingConf

This container contains the configuration for the Mode setting of the MCU.

Note: Implementation Specific Parameter.

Included subcontainers:

#### • None

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF    |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | Infinite                         |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |

## 4.205 Parameter McuMode

This parameter shall represent the ID of the MCU mode.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | true                             |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | 0                                |
| max                          | 255                              |
| min                          | 0                                |

## 4.206 Parameter McuPowerMode

This parameter selects the Power Mode to be used.

For valid Mode transitions refers to Power mode state diagram from Reference Manual.

| Property                     | Value                                              |
|------------------------------|----------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                         |
| origin                       | NXP                                                |
| ${\it symbolicNameValue}$    | false                                              |
| lowerMultiplicity            | 1                                                  |
| upperMultiplicity            | 1                                                  |
| postBuildVariantMultiplicity | N/A                                                |
| multiplicityConfigClasses    | N/A                                                |
| postBuildVariantValue        | true                                               |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                   |
|                              | VARIANT-POST-BUILD: POST-BUILD                     |
| defaultValue                 | RUN                                                |
| literals                     | ['RUN', 'HSRUN', 'VLPR', 'VLPS', 'STOP1', 'STOP2'] |

## 4.207 Parameter McuEnableSleepOnExit

Indicates sleep-on-exit when returning from Handler mode to Thread mode:

- 0 Do not sleep when returning to Thread mode.
- 1 Enter sleep, or deep sleep, on return from an ISR.

Setting this bit to 1 enables an interrupt driven application to avoid returning to an empty main application.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.208}\quad {\bf Container\ McuRamSectorSettingConf}$

This container contains the configuration for the RAM Sector setting.

Included subcontainers:

• None

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF    |
| lowerMultiplicity            | 0                                |
| upperMultiplicity            | Infinite                         |
| postBuildVariantMultiplicity | false                            |
| multiplicityConfigClasses    | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |

## 4.209 Parameter McuRamSectorId

This parameter shall represent the ID of the MCU RAM Sector configuration.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | true                             |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | 0                                |
| max                          | 4294967295                       |
| min                          | 0                                |

## 4.210 Parameter McuRamDefaultValue

This parameter shall represent the Data pre-setting to be initialized.

Default value is 0xbabababa.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0                                |
| max                          | 255                              |
| min                          | 0                                |

## 4.211 Parameter McuRamSectionBaseAddress

This parameter represents the RAM section base address.

The address must be aligned to 4 bytes.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 536838144                        |
| max                          | 536899583                        |
| min                          | 536838144                        |

## 4.212 Parameter McuRamSectionSize

This parameter represents the RAM section size in bytes.

The size must be multiple of 4.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 1024                             |
| max                          | 61440                            |
| min                          | 0                                |

### 4.213 Parameter McuRamSectionWriteSize

This parameter shall define the size in bytes of data which can be written into RAM at once.

The ram write size is currently restricted to {1, 2, 4, 8} bytes.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | AUTOSAR_ECUC                     |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 8                                |
| max                          | 4294967295                       |
| min                          | 0                                |

## 4.214 Parameter McuRamSectionBaseAddrLinkerSym

This parameter represents the RAM section base address.

The address must be aligned to 4 bytes.

If this parameter is empty, then the integer values from "McuRamSectionBaseAddress" will be used.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-STRING-PARAM-DEF            |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 |                                  |

## 4.215 Parameter McuRamSectionSizeLinkerSym

This parameter represents the RAM section size in bytes.

The size must be multiple of 4.

If this parameter is empty, then the integer values from "McuRamSectionSize" will be used.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-STRING-PARAM-DEF            |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 |                                  |

# 4.216 Container McuInterruptEvents

Configuration for different interrupts handled by MCU.

Note: Implementation specific Container.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.217 Parameter McuVoltageErrorEvent

Power Management Unit Fault Monitoring Interrupts.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| ${\it symbolicNameValue}$    | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

### 4.218 Parameter McuAlternateResetEvent

Some events can generate an interrupt from RCM.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | false                            |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: PRE-COMPILE  |
| defaultValue                 | false                            |

# 4.219 Container McuResetConfig

The Reset Control Module (MC\_RCM) centralizes the different reset sources and manages the reset sequence of the device.

Note: Implementation Specific Parameter.

Included subcontainers:

- $\bullet \quad McuSystemInterruptEnable\\$
- $\bullet \quad McuReset Generator Configuration \\$

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

### 4.220 Parameter McuResetPinFilterBusClockSelect

RCM\_RPC[RSTFLTSEL] - Reset Pin Filter Bus Clock Select.

Selects the reset pin bus clock filter width. Transitions for less than (RSTFLTSEL+1) bus clock cycles are always filtered, transitions equal to (RSTFLTSEL+1) bus clock cycles may be filtered.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-INTEGER-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | 0                                |
| max                          | 31                               |
| min                          | 0                                |

## ${\bf 4.221} \quad {\bf Parameter} \ {\bf McuResetPinFilterInStopMode}$

 $\operatorname{RCM}_{\operatorname{RPC}}[\operatorname{RSTFLTSS}]$  - Reset Pin Filter Select in Stop Mode.

Selects how the reset pin filter is enabled in any stop mode.

0 - All filtering disabled.

1 - LPO clock filter enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                                                |  |
|------------------------------|------------------------------------------------------|--|
| type                         | ECUC-ENUMERATION-PARAM-DEF                           |  |
| origin                       | NXP                                                  |  |
| ${\it symbolicNameValue}$    | false                                                |  |
| lowerMultiplicity            | 1                                                    |  |
| upperMultiplicity            | 1                                                    |  |
| postBuildVariantMultiplicity | N/A                                                  |  |
| multiplicityConfigClasses    | N/A                                                  |  |
| postBuildVariantValue        | true                                                 |  |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                     |  |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                       |  |
| defaultValue                 | ALL_FILTERING_DISABLE                                |  |
| literals                     | ['ALL_FILTERING_DISABLE', 'LPO_CLOCK_FILTER_ENABLE'] |  |

### 4.222 Parameter McuResetPinFilterInRunAndWait

 $RCM\_RPC[RSTFLTSRW]$  - Reset Pin Filter Select in Run and Wait Modes.

Selects how the reset pin filter is enabled in run and wait modes.

- 0 All filtering disabled.
- 1 Bus clock filter enabled for normal operation.
- 2 LPO clock filter enabled for normal operation.

| Property                     | Value                      |
|------------------------------|----------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF |
| origin                       | NXP                        |
| symbolicNameValue            | false                      |
| lowerMultiplicity            | 1                          |
| upperMultiplicity            | 1                          |
| postBuildVariantMultiplicity | N/A                        |
| multiplicityConfigClasses    | N/A                        |
| postBuildVariantValue        | true                       |

| Property           | Value                                                                                |
|--------------------|--------------------------------------------------------------------------------------|
| valueConfigClasses | VARIANT-PRE-COMPILE: PRE-COMPILE                                                     |
| varueComigClasses  | VARIANT-POST-BUILD: POST-BUILD                                                       |
| defaultValue       | ALL_FILTERING_DISABLE                                                                |
| literals           | ['ALL_FILTERING_DISABLE', 'BUS_CLOCK_FILTER_ENABLE', 'LPO←<br>_CLOCK_FILTER_ENABLE'] |

## 4.223 Container McuSystemInterruptEnable

Configures RCM\_SRIE

This registers delays the assertion of a system reset for a period of time (DELAY field) while an interrupt is generated.

This allows software to perform a graceful shutdown.

A Chip POR source cannot be delayed by this feature, and entering Stop mode will terminate the delay.

The SRS will only update after the system reset occurs.

Note: Implementation specific Container.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

# ${\bf 4.224} \quad {\bf Parameter} \ {\bf McuResetDelayTime}$

RCM\_SRIE[DELAY] - Reset Delay Time.

Configures the maximum reset delay time from when the interrupt is asserted and the system reset occurs.

- 0 10 LPO cycles.
- 1 34 LPO cycles.
- 2 130 LPO cycles.
- 2 514 LPO cycles.

| Property                     | Value                                                                                               |
|------------------------------|-----------------------------------------------------------------------------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF                                                                          |
| origin                       | NXP                                                                                                 |
| symbolicNameValue            | false                                                                                               |
| lowerMultiplicity            | 1                                                                                                   |
| upperMultiplicity            | 1                                                                                                   |
| postBuildVariantMultiplicity | N/A                                                                                                 |
| multiplicityConfigClasses    | N/A                                                                                                 |
| postBuildVariantValue        | true                                                                                                |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE                                                                    |
| varueComigClasses            | VARIANT-POST-BUILD: POST-BUILD                                                                      |
| defaultValue                 | DELAY_10_LPO_CYCLES                                                                                 |
| literals                     | ['DELAY_10_LPO_CYCLES', 'DELAY_34_LPO_CYCLES', 'DELAY_130←<br>_LPO_CYCLES', 'DELAY_514_LPO_CYCLES'] |

## ${\bf 4.225} \quad {\bf Parameter} \ {\bf McuStopAcknowledgeErrorInterrupt}$

 $\ensuremath{\mathsf{RCM\_SRIE}}[\ensuremath{\mathsf{SACKERR}}]$  - Stop Acknowledge Error Interrupt.

0 - Interrupt disabled.

 ${\bf 1}$  - Interrupt enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.226} \quad {\bf Parameter} \ {\bf McuMDMAPSystemResetInterrupt}$

 $\ensuremath{\mathsf{RCM\_SRIE}} [\ensuremath{\mathsf{MDM\_AP}}]$  - MDM-AP System Reset Request.

 $\boldsymbol{0}$  - Interrupt disabled.

1 - Interrupt enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.227} \quad {\bf Parameter\ McuSoftware Interrupt}$

 $RCM\_SRIE[SW]$  - Software Interrupt.

 $\boldsymbol{0}$  - Interrupt disabled.

1 - Interrupt enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.228} \quad {\bf Parameter} \ {\bf McuCoreLockupInterrupt}$

 $RCM\_SRIE[LOCKUP]$  - Core Lockup Interrupt.

0 - Interrupt disabled.

1 - Interrupt enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.229} \quad {\bf Parameter} \ {\bf McuJTAGResetInterrupt}$

 $\operatorname{RCM\_SRIE}[\operatorname{JTAG}]$  -  $\operatorname{JTAG}$  generated reset.

0 - Interrupt disabled.

 ${\bf 1}$  - Interrupt enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## ${\bf 4.230 \quad Parameter \ McuGlobal Interrupt}$

 $\operatorname{RCM\_SRIE}[\operatorname{GIE}]$  - Global Interrupt Enable.

0 - All interrupt sources disabled.

1 - All interrupt sources enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.231} \quad {\bf Parameter} \ {\bf McuExternalResetPinInterrupt}$

 $\operatorname{RCM\_SRIE}[\operatorname{PIN}]$  - External Reset Pin Interrupt.

0 - Interrupt disabled.

 ${\bf 1}$  - Interrupt enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.232 Parameter McuWatchdogInterrupt

 $\operatorname{RCM\_SRIE}[\operatorname{WDOG}]$  - Watchdog Interrupt.

0 - Interrupt disabled.

1 - Interrupt enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.233} \quad {\bf Parameter} \ {\bf McuCMULossOfClockResetInterrupt}$

 $\ensuremath{\mathsf{RCM\_SRIE}}[\ensuremath{\mathsf{CMU\_LOC}}]$  -  $\ensuremath{\mathsf{CMU}}$  Loss-of-Clock Reset Interrupt.

0 - Interrupt disabled.

 ${\bf 1}$  - Interrupt enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## ${\bf 4.234} \quad {\bf Parameter} \ {\bf McuLossOfLockInterrupt}$

 $\operatorname{RCM\_SRIE}[\operatorname{LOL}]$  - Loss of Lock Interrupt.

0 - Interrupt disabled.

1 - Interrupt enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.235} \quad {\bf Parameter\ McuLossOfClockInterrupt}$

 $\operatorname{RCM\_SRIE}[\operatorname{LOC}]$  - Loss of Clock Interrupt.

0 - Interrupt disabled.

 ${\bf 1}$  - Interrupt enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.236 Container McuResetGeneratorConfiguration

Configures AEC\_AE\_RSTGEN\_CFG[RSTGEN\_CFG]- Configures reset generator.

Set this bit to activate IP (this deasserts hard reset input port of IP).

Individual control over:

- 0: regs\_otp (resets OTP register interface, not mirror regs)
- 1: can\_phy (do not activate CANPHY if VERID.VARIANT says CANPHY is disabled)
- 2: lin phy HP (do not activate LINPHY if VERID. VARIANT says LINPHY is disabled)
- 3: lin\_phy LP (do not activate LINPHY if VERID.VARIANT says LINPHY is disabled)
- 4: gdu
- 5: hvi
- 6: dpga
- 7: tempsensor
- 8: cxpi (do not activate CXPI if VERID. VARIANT says CXPI is disabled, or if using LINPHY in noncxpi mode)

Note: Implementation specific Container.

Included subcontainers:

#### • None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.237 Parameter McuRegsOtpReset

Regs\_otp (resets OTP register interface, not mirror regs)

- 0 Regs Otp Reset disabled.
- 1 Regs Otp Reset enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

## 4.238 Parameter McuCanPhyReset

Can\_phy (do not activate CANPHY if VERID.VARIANT says CANPHY is disabled)

0 - CANPHY Reset disabled.

1 - CANPHY Reset enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.239 Parameter McuLinPhyHpReset

Lin\_phy HP (do not activate LINPHY if VERID.VARIANT says LINPHY is disabled).

0 - LINPHY HP Reset disabled.

### 1 - LINPHY HP Reset enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.240 Parameter McuLinPhyLpReset

Lin\_phy LP (do not activate LINPHY if VERID.VARIANT says LINPHY is disabled).

0 - LINPHY LP Reset disabled.

1 - LINPHY LP Reset enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.241 Parameter McuGduReset

GDU resset.

0 - GDU Reset disabled.

1 - GDU Reset enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.242 Parameter McuHviReset

HVI resset.

0 - HVI Reset disabled.

1 - HVI Reset enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# 4.243 Parameter McuDpgaReset

DPGA resset.

0 - DPGA Reset disabled.

1 - DPGA Reset enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

# ${\bf 4.244} \quad {\bf Parameter} \ {\bf McuTempsensorReset}$

Tempsensor resset.

0 - Tempsensor Reset disabled.

1 - Tempsensor Reset enabled.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.245 Parameter McuCxpiReset

Cxpi (do not activate CXPI if VERID.VARIANT says CXPI is disabled, or if using LINPHY in noncxpi mode).

0 - Cxpi Reset disabled.

1 - Cxpi Reset enabled.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.246 Container McuPowerControl

Note: Implementation Specific Parameter.

Included subcontainers:

- McuPMC\_Config
- McuPMC\_AE\_Config

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## 4.247 Container McuPMC\_Config

This PMC Control Register contains the various control settings of the PMC block.

Note: Implementation Specific Parameter.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## ${\bf 4.248} \quad {\bf Parameter} \ {\bf McuLowVoltageDetectInterruptEnable}$

 $PMC\_LVDSC1[LVDIE]$  - Low Voltage Detect Interrupt Enable.

This bit enables hardware interrupt requests for LVDF.

- 0 Hardware interrupt disabled (use polling).
- 1 Request a hardware interrupt when LVDF = 1.

- Implementation Specific Parameter.
- Only support for 1xx series of devices.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.249 Parameter McuLowVoltageDetectResetEnable

PMC\_LVDSC1[LVDRE] - Low Voltage Detect Reset Enable.

This bit enables the low voltage detect events to generate a system reset.

- 0 No system resets on low voltage detect events.
- 1 If the supply voltage falls below VLVD, a system reset will be generated.

#### Note:

- Implementation Specific Parameter.
- Only support for 1xx series of devices.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## ${\bf 4.250 \quad Parameter \ McuLowVoltage Warning Interrupt Enable}$

PMC\_LVDSC2[LVWIE] - Low-Voltage Warning Interrupt Enable.

This bit enables hardware interrupt requests for LVWF.

- 0 Hardware interrupt disabled (use polling).
- 1 Request a hardware interrupt when LVWF = 1.

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-BOOLEAN-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.251 Parameter McuLPODisable

PMC\_REGSC[LPODIS] - This bit enables or disable the low power oscillator.

After disabling the LPO a time of 2 LPO clock cycles is required before it is allowed to enable it

again. Violating this waiting time of 2 cycles can result in malfunction of the LPO.

unchecked - Low power oscillator enabled.

checked - Low power oscillator disabled.

Note: The reset delay feature requires the LPO clock to remain active.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.252 Parameter McuClockBiasDisable

 ${\it PMC\_REGSC[CLKBIASDIS]}$  - Clock Bias Disable Bit.

This bit disables the bias currents and reference voltages for some clock modules in order to further reduce power consumption in VLPS mode.

Note: While using this bit, it must be ensured that respective clock modules are disabled in VLPS mode.

Else, severe malfunction of clock modules will happen.

unchecked - No effect.

checked - In VLPS mode, the bias currents and reference voltages for the following clock modules are disabled: SIRC, FIRC, PLL.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.253 Parameter McuLowPowerBiasEnable

PMC\_REGSC[BIASEN] - Bias Enable Bit.

This bit enables source and well biasing for the core logic in low power mode. In full performance mode this bit has no effect. This is useful to further reduce MCU power consumption in low power mode. unchecked - Biasing disabled, core logic can run in full performance.

checked - Biasing enabled, core logic is slower and there are restrictions in allowed system clock speed.

| Property          | Value                  |
|-------------------|------------------------|
| type              | ECUC-BOOLEAN-PARAM-DEF |
| origin            | NXP                    |
| symbolicNameValue | false                  |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.254 Container McuPMC\_AE\_Config

This PMC\_AE Control Register contains the various control settings of the PMC\_AE block.

Note: Implementation Specific Parameter.

Included subcontainers:

• None

| Property                     | Value                         |
|------------------------------|-------------------------------|
| type                         | ECUC-PARAM-CONF-CONTAINER-DEF |
| lowerMultiplicity            | 1                             |
| upperMultiplicity            | 1                             |
| postBuildVariantMultiplicity | N/A                           |
| multiplicityConfigClasses    | N/A                           |

## ${\bf 4.255} \quad {\bf Parameter} \ {\bf McuLowVoltageDetectInterruptsOnVLSE} \\ {\bf nable}$

PMC\_MONITOR[LVDVLSIE] - LVD on VLS interrupt enable.

This is to enable interrupt for low voltage detect on VLS (GDU) power domain.

An interrupt will be requested in case of LVDVLSF=1.

- 0 Low voltage detect interrupts on VLS disabled.
- 1 Low voltage detect interrupts on VLS enabled.

- Implementation Specific Parameter.
- Only support for S32M2xx series of devices.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## ${\bf 4.256} \quad {\bf Parameter} \ {\bf McuLowVoltageDetectInterruptsOnVDDCE} nable$

 $\ensuremath{\mathsf{PMC\_MONITOR}}\xspace[\ensuremath{\mathsf{LVDCIE}}\xspace]$  - LVD on VDDC interrupt enable.

This is to enable interrupt for low voltage detect on VDDC power domain.

An interrupt will be requested in case of LVDCF=1.

- 0 Low voltage detect interrupts on VDDC disabled.
- 1 Low voltage detect interrupts on VDDC enabled.

- Implementation Specific Parameter.
- Only support for S32M2xx series of devices.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## ${\bf 4.257} \quad {\bf Parameter} \ {\bf McuHighVoltageDetectInterruptOnVDDEnable}$

PMC\_MONITOR[HVDVDDIE] - HVD on VDD interrupt enable.

This is to enable interrupt for high voltage detection on VDD supply.

An interrupt will be requested in case of HVDVDDF=1.

- 0 High voltage detect interrupt disabled.
- 1 High voltage detect interrupt enabled.

#### Note:

- Implementation Specific Parameter.
- Only support for S32M2xx series of devices.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.258 Parameter

# McuHighVoltageDetectInterruptOnVDDINTAndVDD15Enable

 $PMC\_MONITOR[HVDINT15IE]$  - HVD on VDD interrupt enable.

This is to enable interrupt for high voltage detection on the A10 internal supplies VDDINT or VDD15.

An interrupt will be requested in case of HVD15F=1 or HVDINTF=1.

- 0 High voltage detect interrupt disabled.
- 1 High voltage detect interrupt enabled.

- Implementation Specific Parameter.
- Only support for S32M2xx series of devices.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

## 4.259 Parameter McuLinphySupplyEnable

 $\ensuremath{\mathsf{PMC\_CONFIG}}\xspace[\ensuremath{\mathsf{LINSUPEN}}\xspace]$  - LINPHY supply enable bit.

Enables the LINPHY supply. If disabled LINPHY is turned high ohmic.  $\,$ 

In case LINPHY is generally not used setting LINSUPEN=0 will save power.

- 0 LINPHY supply is high ohmic (off).
- 1 LINPHY supply is as selected by LINSUPSEL bit.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | true                             |

### 4.260 Parameter McuVDDCEnable

PMC\_CONFIG[VDDCEN] - VDDC enable bit.

This Bit enables the VDDC supply.

A PMC internal regulator generates the VDDC from VPRE supply.

VDDC is the 5V supply for the CAN physical interface IP.

0 - VDDC is disabled.

1 - VDDC is enabled and regulated to 5V.

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-BOOLEAN-PARAM-DEF           |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | false                            |

### 4.261 Parameter McuLvdVlsSelect

 $PMC\_CONFIG[LVDVLSSEL]$  - LVD VLS select.

The LVD (Low-Voltage-Dectection) threshold for generated VLS supply is selectable. There are two options.

 $5\_5V$  - LVD threshold on VLS supply is 5.5V.

 $6\_5V$  - LVD threshold on VLS supply is 6.5V.

| Property          | Value                      |
|-------------------|----------------------------|
| type              | ECUC-ENUMERATION-PARAM-DEF |
| origin            | NXP                        |
| symbolicNameValue | false                      |

| Property                     | Value                            |
|------------------------------|----------------------------------|
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | LVD_6_5V                         |
| literals                     | ['LVD_5_5V', 'LVD_6_5V']         |

## 4.262 Parameter McuLinphySupplySelect

 ${\rm PMC\_CONFIG[LINSUPSEL]}$  - LINPHY supply select.

Selects LINPHY supply to be either connected to VSUP pin or HD pin (GDU).

In case using the boost option in GDU, the LINPHY supply must be on HD pin.

0b - LINPHY supply connects to VSUP pin.

1b - LINPHY supply connects to HD pin (of GDU).

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | VSUP_PIN                         |
| literals                     | ['VSUP_PIN', 'HD_PIN']           |

## ${\bf 4.263}\quad {\bf Parameter}\ {\bf McuVddVoltageLevelSelect}$

 $\ensuremath{\mathsf{PMC\_CONFIG[VDDSEL5V]}}$  - VDD voltage level select.

Selects VDD (supply for MCU) to be either 3.3V or 5V.

 $3\_3\mathrm{V}$  - VDD is regulated to 3.3V.

 $5\mathrm{V}$  -  $\mathrm{VDD}$  is regulated to  $5\mathrm{V}.$ 

Note: Implementation Specific Parameter.

| Property                     | Value                            |
|------------------------------|----------------------------------|
| type                         | ECUC-ENUMERATION-PARAM-DEF       |
| origin                       | NXP                              |
| symbolicNameValue            | false                            |
| lowerMultiplicity            | 1                                |
| upperMultiplicity            | 1                                |
| postBuildVariantMultiplicity | N/A                              |
| multiplicityConfigClasses    | N/A                              |
| postBuildVariantValue        | true                             |
| valueConfigClasses           | VARIANT-PRE-COMPILE: PRE-COMPILE |
|                              | VARIANT-POST-BUILD: POST-BUILD   |
| defaultValue                 | VDD_3_3V                         |
| literals                     | ['VDD_3_3V', 'VDD_5V']           |

This chapter describes the Tresos configuration plug-in for the driver Driver. The most of the parameters are described below.

# **Chapter 5**

## **Module Index**

# 5.1 Software Specification

Here is a list of all modules:

| lock Ip Driver | 169 |
|----------------|-----|
| Cu Driver      | 188 |
| ower Ip Driver | 202 |
| am Ip Driver   | 212 |

## **Chapter 6**

### **Module Documentation**

### 6.1 Clock Ip Driver

### 6.1.1 Detailed Description

#### **Data Structures**

- struct Clock\_Ip\_RegisterValueType

  Register value structure. Implements Clock\_Ip\_RegisterValueType\_Class. More...
- struct Clock\_Ip\_RegisterIndexType

 $Register\ index\ structure.\ Implements\ Clock\_Ip\_RegisterIndexType\_Class.\ \underline{\textit{More...}}$ 

- struct Clock\_Ip\_IrcoscConfigType
  - Clock Source IRCOSC configuration structure. Implements Clock\_Ip\_IrcoscConfigType\_Class. More...
- struct Clock\_Ip\_XoscConfigType
  - CGM Clock Source XOSC configuration structure. Implements Clock\_Ip\_XoscConfigType\_Class. More...
- struct Clock\_Ip\_PllConfigType
  - CGM Clock Source PLLDIG configuration structure. Implements Clock\_Ip\_PllConfigType\_Class. More...
- struct Clock\_Ip\_SelectorConfigType
  - Clock selector configuration structure. Implements Clock\_Ip\_SelectorConfigType\_Class. More...
- struct Clock\_Ip\_DividerConfigType
  - Clock divider configuration structure. Implements Clock\_Ip\_DividerConfigType\_Class. More...
- struct Clock\_Ip\_DividerTriggerConfigType
  - Clock divider trigger configuration structure. Implements Clock\_Ip\_DividerTriggerConfigType\_Class. More...
- struct Clock\_Ip\_FracDivConfigType
  - Clock fractional divider configuration structure. Implements Clock\_Ip\_FracDivConfigType\_Class. More...
- struct Clock\_Ip\_ExtClkConfigType
  - Clock external clock configuration structure. Implements Clock\_Ip\_ExtClkConfigType\_Class. More...
- struct Clock\_Ip\_PcfsConfigType
  - ${\it Clock Source PCFS configuration structure. \ Implements \ {\it Clock\_Ip\_PcfsConfigType\_Class.} \ {\it More...}}$
- struct Clock\_Ip\_GateConfigType
  - $Clock\ gate\ clock\ configuration\ structure.\ Implements\ Clock\_Ip\_GateConfigType\_Class.\ More...$
- struct Clock\_Ip\_CmuConfigType

#### **Module Documentation**

Clock cmu configuration structure. Implements Clock\_Ip\_CmuConfigType\_Class. More...

struct Clock\_Ip\_ConfiguredFrequencyType

Configured frequency structure. Implements Clock\_Ip\_ConfiguredFrequencyType\_Class. More...

• struct Clock\_Ip\_SpecificPerpihParamType

Clock Specific peripheral configure. Implements Clock\_Ip\_SpecificPerpihParamType\_Class. More...

• struct Clock\_IP\_SpecificPeriphConfigType

Clock Specific peripheral structure. Implements Clock\_IP\_SpecificPeriphConfigType\_Class. More...

• struct Clock\_Ip\_ClockConfigType

 $Clock\ configuration\ structure.\ Implements\ Clock\_Ip\_ClockConfigType\_Class.\ \underline{More...}$ 

### Types Reference

• typedef void(\* Clock\_Ip\_NotificationsCallbackType) (Clock\_Ip\_NotificationType Error, Clock\_Ip\_NameType ClockName)

 $Clock\ notifications\ callback\ type.\ Implements\ ClockNotifications CallbackType\_Class.$ 

#### Enum Reference

- $\bullet \ \ enum \ Clock\_Ip\_ClockNameSourceType$ 
  - Clock ip source type.
- enum Clock Ip PllStatusReturnType

 $Clock\ pll\ status\ return\ codes.$ 

• enum Clock\_Ip\_DfsStatusType

Clock dfs status return codes.

• enum Clock\_Ip\_CommandType

Clock ip specific commands.

• enum Clock\_Ip\_PowerModesType

Power modes.

• enum Clock\_Ip\_PowerNotificationType

Power mode notification.

• enum Clock\_Ip\_NameType

Clock names.

 $\bullet$  enum Clock\_Ip\_StatusType

Clock ip status return codes.

• enum Clock\_Ip\_PllStatusType

Clock ip pll status return codes.

• enum Clock\_Ip\_CmuStatusType

Clock ip cmu status return codes.

• enum Clock\_Ip\_NotificationType

Clock ip report error types.

• enum Clock\_Ip\_TriggerDividerType

Clock ip trigger divider type.

• enum Clock\_Ip\_SpecificPeriphParamType

specific peripheral.

#### **Function Reference**

• Clock\_Ip\_StatusType Clock\_Ip\_Init (Clock\_Ip\_ClockConfigType const \*Config)

Set clock configuration according to pre-defined structure.

void Clock\_Ip\_InitClock (Clock\_Ip\_ClockConfigType const \*Config)

Set the PLL and other MCU specific clock options.

• Clock Ip PllStatusType Clock Ip GetPllStatus (void)

Returns the lock status of the PLL.

• void Clock\_Ip\_DistributePll (void)

 $Activates\ the\ PLL\ in\ MCU\ clock\ distribution.$ 

• void Clock\_Ip\_InstallNotificationsCallback (Clock\_Ip\_NotificationsCallbackType Callback)

Install a clock notifications callback.

• void Clock\_Ip\_DisableClockMonitor (Clock\_Ip\_NameType ClockName)

Disables a clock monitor.

• void Clock Ip DisableModuleClock (Clock Ip NameType ClockName)

Disables clock for a peripheral.

• void Clock\_Ip\_EnableModuleClock (Clock\_Ip\_NameType ClockName)

Enables clock for a peripheral.

 void Clock\_Ip\_PowerModeChangeNotification (Clock\_Ip\_PowerModesType PowerMode, Clock\_Ip\_PowerNotificationTy Notification)

Sends notifications regarding power mode transition.

• uint32 Clock\_Ip\_GetClockFrequency (Clock\_Ip\_NameType ClockName)

Gets the clock frequency for a specific clock name.

• void Clock\_Ip\_StartTimeout (uint32 \*StartTimeOut, uint32 \*ElapsedTimeOut, uint32 \*TimeoutTicksOut, uint32 TimeoutUs)

Initializes a starting reference point for timeout.

• boolean Clock\_Ip\_TimeoutExpired (uint32 \*StartTimeInOut, uint32 \*ElapsedTimeInOut, uint32 Timeout← Ticks)

Checks for timeout condition.

#### 6.1.2 Data Structure Documentation

### ${\bf 6.1.2.1 \quad struct \ Clock\_Ip\_RegisterValueType}$

Register value structure. Implements Clock\_Ip\_RegisterValueType\_Class.

Definition at line 3013 of file Clock Ip Types.h.

Data Fields

| Type     | Name         | Description       |
|----------|--------------|-------------------|
| uint32 * | RegisterAddr | Register address. |
| uint32   | RegisterData | Register value.   |

#### Module Documentation

### 6.1.2.2 struct Clock\_Ip\_RegisterIndexType

Register index structure. Implements Clock\_Ip\_RegisterIndexType\_Class.

Definition at line 3024 of file Clock\_Ip\_Types.h.

#### Data Fields

| ſ | Type   | Name       | Description                    |
|---|--------|------------|--------------------------------|
| Ī | uint16 | StartIndex | Start index in register array. |
| Ī | uint16 | EndIndex   | End index in register array.   |

### $\bf 6.1.2.3 \quad struct \ Clock\_Ip\_IrcoscConfigType$

 ${\bf Clock\ Source\ IRCOSC\ configuration\ structure.\ Implements\ Clock\_Ip\_IrcoscConfigType\_Class.}$ 

Definition at line 3037 of file Clock\_Ip\_Types.h.

#### Data Fields

| Type              | Name               | Description                     |
|-------------------|--------------------|---------------------------------|
| Clock_Ip_NameType | Name               | Clock name associated to ircosc |
| uint16            | Enable             | Enable ircosc.                  |
| uint8             | Regulator          | Enable regulator.               |
| uint8             | Range              | Ircosc range.                   |
| uint8             | LowPowerModeEnable | Ircosc enable in VLP mode       |
| uint8             | StopModeEnable     | Ircosc enable in STOP mode      |

#### $6.1.2.4 \quad struct \ Clock\_Ip\_XoscConfigType$

 $CGM\ Clock\ Source\ XOSC\ configuration\ structure.\ Implements\ Clock\_Ip\_XoscConfigType\_Class.$ 

Definition at line 3053 of file Clock\_Ip\_Types.h.

Data Fields

| Type              | Name             | Description                    |
|-------------------|------------------|--------------------------------|
| Clock_Ip_NameType | Name             | Clock name associated to xosc  |
| uint32            | Freq             | External oscillator frequency. |
| uint16            | Enable           | Enable xosc.                   |
| uint16            | StartupDelay     | Startup stabilization time.    |
| uint8             | BypassOption     | XOSC bypass option             |
| uint8             | CompEn           | Comparator enable              |
| uint8             | TransConductance | Crystal overdrive protection   |

# Data Fields

| Type  | Name                | Description                |
|-------|---------------------|----------------------------|
| uint8 | Gain                | Gain value                 |
| uint8 | Monitor             | Monitor type               |
| uint8 | AutoLevelController | Automatic level controller |

# $\bf 6.1.2.5 \quad struct \ Clock\_Ip\_PllConfigType$

 $CGM\ Clock\ Source\ PLLDIG\ configuration\ structure.\ Implements\ Clock\_Ip\_PllConfigType\_Class.$ 

Definition at line 3076 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name                      | Description                                        |
|-------------------|---------------------------|----------------------------------------------------|
| Clock_Ip_NameType | Name                      | Clock name associated to pll                       |
| uint16            | Enable                    | Enable pll.                                        |
| Clock_Ip_NameType | InputReference            | Input reference.                                   |
| uint8             | Bypass                    | Bypass pll.                                        |
| uint8             | Predivider                | Input clock predivider.                            |
| uint16            | Multiplier                | Clock multiplier.                                  |
|                   |                           |                                                    |
| uint8             | Postdivider               | Clock postidivder.                                 |
| uint16            | NumeratorFracLoopDiv      | Numerator of fractional loop division factor (MFN) |
| uint8             | MulFactorDiv              | Multiplication factor divider (MFD)                |
| uint8             | FrequencyModulationBypass | Enable/disable modulation                          |
| uint8             | ModulationType            | Modulation type                                    |
| uint16            | ModulationPeriod          | Stepsize - modulation period                       |
| uint16            | IncrementStep             | Stepno - step no                                   |
| uint8             | SigmaDelta                | Sigma Delta Modulation Enable                      |
| uint8             | DitherControl             | Dither control enable                              |
| uint8             | DitherControlValue        | Dither control value                               |
| uint8             | Monitor                   | Monitor type                                       |
| uint16            | Dividers[3U]              | Dividers values                                    |

# 6.1.2.6 struct Clock\_Ip\_SelectorConfigType

 ${\bf Clock\ selector\ configuration\ structure.\ Implements\ Clock\_Ip\_SelectorConfigType\_Class.}$ 

Definition at line 3113 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name  | Description                       |
|-------------------|-------|-----------------------------------|
| Clock_Ip_NameType | Name  | Clock name associated to selector |
| Clock_Ip_NameType | Value | Name of the selected input source |

# 6.1.2.7 struct Clock\_Ip\_DividerConfigType

 ${\bf Clock\ divider\ configuration\ structure.\ Implements\ Clock\_Ip\_DividerConfigType\_Class.}$ 

Definition at line 3124 of file Clock\_Ip\_Types.h.

## Data Fields

| Type              | Name        | Description                                                    |
|-------------------|-------------|----------------------------------------------------------------|
| Clock_Ip_NameType | Name        | Clock name associated to divider.                              |
| uint32            | Value       | Divider value - if value is zero then divider is disabled.     |
| uint8             | Options[1U] | Option divider value - this value depend hardware information. |

# $6.1.2.8 \quad struct \ Clock\_Ip\_DividerTriggerConfigType$

Clock divider trigger configuration structure. Implements Clock\_Ip\_DividerTriggerConfigType\_Class.

Definition at line 3135 of file Clock\_Ip\_Types.h.

## Data Fields

| Type                        | Name        | Description                                                                                               |
|-----------------------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Clock_Ip_NameType           | Name        | Clock name associated to divider for which trigger is configured.                                         |
| Clock_Ip_TriggerDividerType | TriggerType | Trigger value - if value is zero then divider is updated immediately, divider is not triggered.           |
| Clock_Ip_NameType           | Source      | Clock name of the common input source of all dividers from<br>the same group that support a common update |

# ${\bf 6.1.2.9 \quad struct \ Clock\_Ip\_FracDivConfigType}$

 ${\bf Clock\ fractional\ divider\ configuration\ structure.\ Implements\ Clock\_Ip\_FracDivConfigType\_Class.}$ 

Definition at line 3149 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name      | Description                                  |  |
|-------------------|-----------|----------------------------------------------|--|
| Clock_Ip_NameType | Name      | Clock name associated to fractional divider. |  |
| uint8             | Enable    | Enable control for port n                    |  |
| uint32            | Value[2U] | Fractional dividers                          |  |

## 6.1.2.10 struct Clock\_Ip\_ExtClkConfigType

 ${\bf Clock\ external\ clock\ configuration\ structure.\ Implements\ Clock\_Ip\_ExtClkConfigType\_Class.}$ 

Definition at line 3161 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name  | Description                                                                                   |
|-------------------|-------|-----------------------------------------------------------------------------------------------|
| Clock_Ip_NameType | Name  | Clock name of the external clock.                                                             |
| uint32            | Value | Enable value - if value is zero then clock is gated, otherwise is enabled in different modes. |

## ${\bf 6.1.2.11 \quad struct \ Clock\_Ip\_PcfsConfigType}$

 ${\bf Clock\ Source\ PCFS\ configuration\ structure.\ Implements\ Clock\_Ip\_PcfsConfigType\_Class.}$ 

Definition at line 3172 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name                  | Description                                                                                                                     |
|-------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Clock_Ip_NameType | Name                  | Clock source from which ramp-down and to which ramp-up are processed.                                                           |
| uint32            | MaxAllowableIDDchange | Maximum variation of current per time (mA/microsec) - max allowable IDD change is determined by the user's power supply design. |
| uint32            | StepDuration          | Step duration of each PCFS step                                                                                                 |
| Clock_Ip_NameType | SelectorName          | Name of the selector that supports PCFS and name is one the inputs that can be selected                                         |
| uint32            | ClockSourceFrequency  | Frequency of the clock source from which ramp-down and to which ramp-up are processed.                                          |

# $\bf 6.1.2.12 \quad struct \ Clock\_Ip\_GateConfigType$

 ${\bf Clock\ gate\ clock\ configuration\ structure.\ Implements\ Clock\_Ip\_GateConfigType\_Class.}$ 

Definition at line 3186 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name   | Description                          |
|-------------------|--------|--------------------------------------|
| Clock_Ip_NameType | Name   | Clock name associated to clock gate. |
| uint16            | Enable | Enable or disable clock              |

# $6.1.2.13 \quad struct \ Clock\_Ip\_CmuConfigType$

 ${\bf Clock\ cmu\ configuration\ structure.\ Implements\ Clock\_Ip\_CmuConfigType\_Class.}$ 

Definition at line 3197 of file Clock\_Ip\_Types.h.

#### Data Fields

| Type                       | Name                    | Description                                                                            |
|----------------------------|-------------------------|----------------------------------------------------------------------------------------|
| Clock_Ip_NameType          | Name                    | Clock name associated to clock monitor.                                                |
| uint8                      | Enable                  | Enable/disable clock monitor                                                           |
| uint32                     | Interrupt               | Enable/disable interrupt                                                               |
| uint32                     | MonitoredClockFrequency | Frequency of the clock source from which ramp-down and to which ramp-up are processed. |
| Clock_Ip_RegisterIndexType | Indexes                 | Register index if register value optimization is enabled.                              |

## 6.1.2.14 struct Clock\_Ip\_ConfiguredFrequencyType

Configured frequency structure. Implements Clock\_Ip\_ConfiguredFrequencyType\_Class.

Definition at line 3210 of file Clock\_Ip\_Types.h.

### Data Fields

| Type              | Name                     | Description                                  |  |
|-------------------|--------------------------|----------------------------------------------|--|
| Clock_Ip_NameType | Name                     | Clock name of the configured frequency value |  |
| uint32            | ConfiguredFrequencyValue | Configured frequency value                   |  |

# $6.1.2.15 \quad struct \ Clock\_Ip\_SpecificPerpihParamType$

 ${\it Clock Specific PerpihParamType\_Class.}$ 

Definition at line 3220 of file Clock\_Ip\_Types.h.

# $6.1.2.16 \quad struct \ Clock\_IP\_SpecificPeriphConfigType$

 ${\bf Clock\ Specific\ PeriphConfigType\_Class.}$ 

Definition at line 3230 of file Clock\_Ip\_Types.h.

# ${\bf 6.1.2.17} \quad {\bf struct} \ {\bf Clock\_Ip\_ClockConfigType}$

 ${\bf Clock\ configuration\ structure.\ Implements\ Clock\_Ip\_ClockConfigType\_Class.}$ 

Definition at line 3240 of file Clock\_Ip\_Types.h.

## Data Fields

| Type                               | Name                          | Description                             |
|------------------------------------|-------------------------------|-----------------------------------------|
| uint32                             | ClkConfigId                   | The ID for Clock configuration          |
| const Clock_Ip_RegisterValueType(* | RegValues)[]                  | Pointer to register values array        |
| uint8                              | IrcoscsCount                  | IRCOSCs count                           |
| uint8                              | XoscsCount                    | XOSCs count                             |
| uint8                              | PllsCount                     | PLLs count                              |
| uint8                              | SelectorsCount                | Selectors count                         |
| uint8                              | DividersCount                 | Dividers count                          |
| uint8                              | DividerTriggersCount          | Divider triggers count                  |
| uint8                              | FracDivsCount                 | Fractional dividers count               |
| uint8                              | ExtClksCount                  | External clocks count                   |
| uint8                              | GatesCount                    | Clock gates count                       |
| uint8                              | PcfsCount                     | Clock pcfs count                        |
| uint8                              | CmusCount                     | Clock cmus count                        |
| uint8                              | ConfigureFrequenciesCount     | Configured frequencies count            |
| Clock_Ip_IrcoscConfigType          | Ircoscs[(2U)]                 | IRCOSCs                                 |
| Clock_Ip_XoscConfigType            | Xoscs[(1U)]                   | XOSCs                                   |
| Clock_Ip_PllConfigType             | Plls[(1U)]                    | PLLs                                    |
| Clock_Ip_SelectorConfigType        | Selectors[(26U)]              | Selectors                               |
| Clock_Ip_DividerConfigType         | Dividers[(17U)]               | Dividers                                |
| Clock_Ip_DividerTriggerConfigType  | DividerTriggers[1U]           | Divider triggers                        |
| Clock_Ip_FracDivConfigType         | FracDivs[1U]                  | Fractional dividers                     |
| Clock_Ip_ExtClkConfigType          | ExtClks[(4U)]                 | External clocks                         |
| Clock_Ip_GateConfigType            | Gates[(39U)]                  | Clock gates                             |
| Clock_Ip_PcfsConfigType            | Pcfs[1U]                      | Progressive clock switching             |
| Clock_Ip_CmuConfigType             | Cmus[1U]                      | Clock cmus                              |
| Clock_IP_SpecificPeriphConfigType  | SpecificPeriphalConfiguration | Clock specific peripheral configuration |
| Clock_Ip_ConfiguredFrequencyType   | Configured Frequencies [(1U)] | Configured frequency values             |

# 6.1.3 Types Reference

# ${\bf 6.1.3.1 \quad Clock\_Ip\_NotificationsCallbackType}$

typedef void(\* Clock\_Ip\_NotificationsCallbackType) (Clock\_Ip\_NotificationType Error, Clock\_Ip\_NameType
ClockName)

 ${\bf Clock\ notifications\ Callback\ Type\_Class.}$ 

Definition at line 3007 of file Clock\_Ip\_Types.h.

# 6.1.4 Enum Reference

## 6.1.4.1 Clock\_Ip\_ClockNameSourceType

enum Clock\_Ip\_ClockNameSourceType

Clock ip source type.

#### Enumerator

| UKNOWN_TYPE  | Clock path from source to this clock name has at least one selector. |  |
|--------------|----------------------------------------------------------------------|--|
| IRCOSC_TYPE  | Source is an internal oscillator.                                    |  |
| XOSC_TYPE    | Source is an external oscillator.                                    |  |
| PLL_TYPE     | Source is a pll.                                                     |  |
| EXT_CLK_TYPE | Source is an external clock.                                         |  |
| SERDES_TYPE  | Source is a SERDES.                                                  |  |

Definition at line 256 of file Clock\_Ip\_Private.h.

# 6.1.4.2 Clock\_Ip\_PllStatusReturnType

enum Clock\_Ip\_PllStatusReturnType

Clock pll status return codes.

# Enumerator

| STATUS_PLL_NOT_ENABLED | Not enabled |
|------------------------|-------------|
| STATUS_PLL_UNLOCKED    | Unlocked    |
| STATUS_PLL_LOCKED      | Locked      |

Definition at line 270 of file Clock\_Ip\_Private.h.

# $6.1.4.3 \quad Clock\_Ip\_DfsStatusType$

enum Clock\_Ip\_DfsStatusType

Clock dfs status return codes.

### Enumerator

| STATUS_DFS_NOT_ENABLED | Not enabled |
|------------------------|-------------|
| STATUS_DFS_UNLOCKED    | Unlocked    |
| STATUS_DFS_LOCKED      | Locked      |

Definition at line 280 of file Clock\_Ip\_Private.h.

# ${\bf 6.1.4.4 \quad Clock\_Ip\_CommandType}$

enum Clock\_Ip\_CommandType

Clock ip specific commands.

### Enumerator

| CLOCK_IP_RESERVED_COMMAND                 | Reserved command          |
|-------------------------------------------|---------------------------|
| CLOCK_IP_INITIALIZE_PLATFORM_COMMAND      | Specific platform objects |
| CLOCK_IP_INITIALIZE_CLOCK_OBJECTS_COMMAND | Initialize clock objects  |
| CLOCK_IP_SET_USER_ACCESS_ALLOWED_COMMAND  | User access allowed       |
| CLOCK_IP_DISABLE_SAFE_CLOCK_COMMAND       | Disable safe clock        |

Definition at line 290 of file Clock\_Ip\_Private.h.

# $6.1.4.5 \quad Clock\_Ip\_PowerModesType$

enum Clock\_Ip\_PowerModesType

Power modes.

Definition at line 194 of file Clock\_Ip\_Types.h.

# 6.1.4.6 Clock\_Ip\_PowerNotificationType

enum Clock\_Ip\_PowerNotificationType

Power mode notification.

Definition at line 205 of file Clock\_Ip\_Types.h.

## 6.1.4.7 Clock\_Ip\_NameType

enum Clock\_Ip\_NameType

Clock names.

Definition at line 215 of file Clock\_Ip\_Types.h.

## 6.1.4.8 Clock\_Ip\_StatusType

enum Clock\_Ip\_StatusType

Clock ip status return codes.

## Enumerator

| CLOCK_IP_SUCCESS | Clock tree was initialized successfully.                         |
|------------------|------------------------------------------------------------------|
| CLOCK_IP_ERROR   | One of the elements timeout, clock tree couldn't be initialized. |

Definition at line 2945 of file Clock\_Ip\_Types.h.

# $6.1.4.9 \quad Clock\_Ip\_PllStatusType$

enum Clock\_Ip\_PllStatusType

Clock ip pll status return codes.

## Enumerator

| CLOCK_IP_PLL_LOCKED           | PLL is locked         |
|-------------------------------|-----------------------|
| CLOCK_IP_PLL_UNLOCKED         | PLL is unlocked       |
| CLOCK_IP_PLL_STATUS_UNDEFINED | PLL Status is unknown |

Definition at line 2953 of file Clock\_Ip\_Types.h.

# $6.1.4.10 \quad Clock\_Ip\_CmuStatusType$

enum Clock\_Ip\_CmuStatusType

Clock ip cmu status return codes.

### Enumerator

| CLOCK_IP_CMU_IN_RANGE         | Frequency is in range               |
|-------------------------------|-------------------------------------|
| CLOCK_IP_CMU_HIGH_FREQ        | Frequency is higher than high limit |
| CLOCK_IP_CMU_LOW_FREQ         | Frequency is lower than low limit   |
| CLOCK_IP_CMU_STATUS_UNDEFINED | CMU status is unknown               |

Definition at line 2962 of file Clock\_Ip\_Types.h.

# ${\bf 6.1.4.11 \quad Clock\_Ip\_NotificationType}$

enum Clock\_Ip\_NotificationType

Clock ip report error types.

## Enumerator

| CLOCK_IP_CMU_ERROR                        | Cmu Fccu notification.            |
|-------------------------------------------|-----------------------------------|
| CLOCK_IP_REPORT_TIMEOUT_ERROR             | Report Timeout Error.             |
| CLOCK_IP_REPORT_FXOSC_CONFIGURATION_ERROR | Report Fxosc Configuration Error. |
| CLOCK_IP_REPORT_CLOCK_MUX_SWITCH_ERROR    | Report Clock Mux Switch Error.    |
| CLOCK_IP_RAM_MEMORY_CONFIG_ENTRY          | Ram config entry point.           |
| CLOCK_IP_RAM_MEMORY_CONFIG_EXIT           | Ram config exit point.            |
| CLOCK_IP_FLASH_MEMORY_CONFIG_ENTRY        | Flash config entry point.         |
| CLOCK_IP_FLASH_MEMORY_CONFIG_EXIT         | Flash config exit point.          |
| CLOCK_IP_ACTIVE                           | Report Clock Active.              |
| CLOCK_IP_INACTIVE                         | Report Clock Inactive.            |
| CLOCK_IP_REPORT_WRITE_PROTECTION_ERROR    | Report Write Protection Error.    |

Definition at line 2971 of file Clock\_Ip\_Types.h.

# ${\bf 6.1.4.12}\quad {\bf Clock\_Ip\_TriggerDividerType}$

```
enum Clock_Ip_TriggerDividerType
```

Clock ip trigger divider type.

Enumerator

| IMMEDIATE_DIVIDER_UPDATE      | Immediate divider update.      |
|-------------------------------|--------------------------------|
| COMMON_TRIGGER_DIVIDER_UPDATE | Common trigger divider update. |

Definition at line 2987 of file Clock\_Ip\_Types.h.

# $6.1.4.13 \quad Clock\_Ip\_SpecificPeriphParamType$

```
enum Clock_Ip_SpecificPeriphParamType
```

specific peripheral.

Definition at line 2995 of file Clock\_Ip\_Types.h.

# 6.1.5 Function Reference

# 6.1.5.1 Clock\_Ip\_Init()

Set clock configuration according to pre-defined structure.

This function sets system to target clock configuration; It sets the clock modules registers for clock mode change.

#### Parameters

| in | Config | Pointer to configuration structure. |
|----|--------|-------------------------------------|
|----|--------|-------------------------------------|

Returns

void

Note

If external clock is used in the target mode, please make sure it is enabled, for example, if the external oscillator is used, please setup correctly.

## 6.1.5.2 Clock\_Ip\_InitClock()

Set the PLL and other MCU specific clock options.

This function initializes the PLL and other MCU specific clock options. The clock configuration parameters are provided via the configuration structure.

This function shall start the PLL lock procedure (if PLL shall be initialized) and shall return without waiting until the PLL is locked.

#### Parameters

| in | Config | Pointer to configuration structure. |
|----|--------|-------------------------------------|
|----|--------|-------------------------------------|

Returns

void

# 6.1.5.3 Clock\_Ip\_GetPllStatus()

Returns the lock status of the PLL.

This function returns status of the PLL: undefined, unlocked or locked. This function returns undefined status if this function is called prior to calling of the function Clock\_Ip\_InitClock

Returns

Status. Pll lock status

## 6.1.5.4 Clock\_Ip\_DistributePll()

Activates the PLL in MCU clock distribution.

This function activates the PLL clock to the MCU clock distribution.

This function removes the current clock source (for example internal oscillator clock) from MCU clock distribution.

Application layer calls this function after the status of the PLL has been detected as locked by the function Clock← \_Ip\_GetPllStatus.

The function Clock\_Ip\_DistributePll shall return without affecting the MCU hardware if the PLL clock has been automatically activated by the MCU hardware.

Returns

void

## 6.1.5.5 Clock\_Ip\_InstallNotificationsCallback()

Install a clock notifications callback.

This function installs a callback for reporting notifications from clock driver

Parameters

| in | Clock_Ip_ | $\_Notifications Callback Type$ | notifications callback |
|----|-----------|---------------------------------|------------------------|
|----|-----------|---------------------------------|------------------------|

Returns

void

## 6.1.5.6 Clock\_Ip\_DisableClockMonitor()

Disables a clock monitor.

This function disables a clock monitor.

### Parameters

| in ClockName | Clock Name. |
|--------------|-------------|
|--------------|-------------|

# Returns

void

# $\bf 6.1.5.7 \quad Clock\_Ip\_DisableModuleClock()$

Disables clock for a peripheral.

This function disables clock for a peripheral.

### Parameters

| in | ClockName | Clock Name. |
|----|-----------|-------------|
|----|-----------|-------------|

### Returns

void

# 6.1.5.8 Clock\_Ip\_EnableModuleClock()

Enables clock for a peripheral.

This function enables clock for a peripheral.

| in | ClockName | Clock Name. |
|----|-----------|-------------|

Returns

void

## 6.1.5.9 Clock\_Ip\_PowerModeChangeNotification()

Sends notifications regarding power mode transition.

This function sends notifications regarding power mode transition. It is called by power driver each time power mode is changed.

#### Parameters

| in | PowerMode | Power mode.              |
|----|-----------|--------------------------|
| in | PowerMode | Power mode notification. |

Returns

void

# $6.1.5.10 \quad Clock\_Ip\_GetClockFrequency()\\$

Gets the clock frequency for a specific clock name.

This function checks the current clock configurations and then calculates the clock frequency for a specific clock name defined in Clock\_Ip\_NameType. Clock modules must be properly configured before using this function. See features.h for supported clock names for different chip families. The returned value is in Hertz. If frequency is required for a peripheral and the module is not clocked, then 0 Hz frequency is returned.

| in | ClockName | Clock names defined in Clock_Ip_NameType |
|----|-----------|------------------------------------------|
|----|-----------|------------------------------------------|

## Returns

frequency Returned clock frequency value in Hertz

# 6.1.5.11 Clock\_Ip\_StartTimeout()

Initializes a starting reference point for timeout.

### Parameters

| out | StartTimeOut    | The starting time from which elapsed time is measured                |
|-----|-----------------|----------------------------------------------------------------------|
| out | ElapsedTimeOut  | The elapsed time to be passed to Clock_Ip_TimeoutExpired             |
| out | TimeoutTicksOut | The timeout value (in ticks) to be passed to Clock_Ip_TimeoutExpired |
| in  | Timeout Us      | The timeout value (in microseconds)                                  |

# 6.1.5.12 Clock\_Ip\_TimeoutExpired()

Checks for timeout condition.

| in,out | StartTimeInOut      | The starting time from which elapsed time is measured         |
|--------|---------------------|---------------------------------------------------------------|
| in,out | Elapsed Time In Out | The accumulated elapsed time from the starting time reference |
| in     | TimeoutTicks        | The timeout limit (in ticks)                                  |

# 6.2 Mcu Driver

# 6.2.1 Detailed Description

## **Data Structures**

• struct Mcu\_ConfigType

Initialization data for the MCU driver. More...

### Macros

• #define MCU\_VENDOR\_ID

Import all data types from lower layers that should be exported. Mcu.h shall include Mcu\_Cfg.h for the API precompiler switches.

# Types Reference

- $\bullet \ \ typedef\ Power\_Ip\_HwIPsConfigType\ Mcu\_HwIPsConfigType\\$ 
  - Mcu driver configuration structure.
- typedef Clock\_Ip\_ClockConfigType Mcu\_ClockConfigType
  - Definition of a Clock configuration.
- typedef Ram\_Ip\_RamConfigType Mcu\_RamConfigType
  - $Definition\ of\ a\ Clock\ configuration.$
- $\bullet \ \ typedef\ Power\_Ip\_ModeConfigType\ Mcu\_ModeConfigType\\$ 
  - Definition of a Mode configuration.

# **Enum Reference**

• enum Mcu\_ClockNotificationType

 $Mcu\_ClockNotificationType.$ 

## **Function Reference**

• void Mcu Init (const Mcu ConfigType \*ConfigPtr)

MCU driver initialization function.

• Std\_ReturnType Mcu\_InitRamSection (Mcu\_RamSectionType RamSection)

MCU driver initialization of Ram sections.

• Std\_ReturnType Mcu\_InitClock (Mcu\_ClockType ClockSetting)

MCU driver clock initialization function.

• void Mcu\_SetMode (Mcu\_ModeType McuMode)

This function sets the MCU power mode.

• Std ReturnType Mcu DistributePllClock (void)

This function activates the PLL clock to the MCU clock distribution.

• Mcu\_PllStatusType Mcu\_GetPllStatus (void)

This function returns the lock status of the PLL.

• Mcu\_ResetType Mcu\_GetResetReason (void)

This function returns the Reset reason.

• Mcu\_RawResetType Mcu\_GetResetRawValue (void)

This function returns the Raw Reset value.

• void Mcu PerformReset (void)

This function performs a microcontroller reset.

• void Mcu\_GetVersionInfo (Std\_VersionInfoType \*versioninfo)

This function returns the Version Information for the MCU module.

Mcu PowerModeStateType Mcu GetPowerModeState (void)

This function returns the System Status (power mode, clock settings) from MC\_ME hw IP. The return value is the content register read from hardware (ME\_GS). The return value shall evidentiate the current running mode, clock settings and activation, etc.

• void Mcu\_DisableCmu (Clock\_Ip\_NameType ClockName)

Disable clock monitoring unit.

• uint32 Mcu\_GetClockFrequency (Clock\_Ip\_NameType ClockName)

Return the frequency of a given clock.

void Mcu\_SleepOnExit (Mcu\_SleepOnExitType SleepOnExit)

This function disable/enable SleepOnExit.

• void Mcu PmcAeConfig (void)

This function configure the Power Management Controller AE. This function configure the Power Management Controller AE of the microcontroller.

void Mcu\_AecResetConfig (void)

This function configure the Reset config AEC. This function configure the Reset config AEC of the microcontroller.

• void Mcu\_ReportDemTimeoutError (void)

Reports timeout error to DEM.

• void Mcu\_ReportDemSwitchModeError (void)

Reports failed switch mode to DEM.

• void Mcu\_Ipw\_SRAMRetentionConfig (Mcu\_SRAMRetenConfigType SRAMRetenConfig)

Configuration for SRAM retention.

## 6.2.2 Data Structure Documentation

### 6.2.2.1 struct Mcu\_ConfigType

Initialization data for the MCU driver.

A pointer to such a structure is provided to the MCU initialization routines for configuration.

Definition at line 169 of file Mcu.h.

#### **Data Fields**

• Mcu\_ClockNotificationType ClkSrcFailureNotification

Clock source failure notification enable configuration.

• const Mcu\_DemConfigType \* DemConfigPtr

DEM error reporting configuration.

• Mcu\_RamSectionType NoRamConfigs

Total number of RAM sections.

• Mcu\_ModeType NoModeConfigs

Total number of MCU modes.

• Mcu\_ClockType NoClkConfigs

Total number of MCU clock configurations.

• const Mcu\_RamConfigType(\* RamConfigArrayPtr )[((uint32) 1U)]

 $RAM\ data\ configuration.$ 

• const Mcu\_ModeConfigType(\* ModeConfigArrayPtr )[((uint32) 6U)]

Power Modes data configuration.

• const Mcu\_HwIPsConfigType \* HwIPsConfigPtr

IPs data generic configuration.

### 6.2.2.1.1 Field Documentation

### 6.2.2.1.1.1 ClkSrcFailureNotification Mcu\_ClockNotificationType ClkSrcFailureNotification

Clock source failure notification enable configuration.

Definition at line 173 of file Mcu.h.

## $6.2.2.1.1.2 \quad DemConfigPtr \quad \texttt{const} \; \; \texttt{Mcu\_DemConfigType*} \; \; \texttt{DemConfigPtr}$

DEM error reporting configuration.

Definition at line 178 of file Mcu.h.

### 6.2.2.1.1.3 NoRamConfigs Mcu\_RamSectionType NoRamConfigs

Total number of RAM sections.

Definition at line 181 of file Mcu.h.

### 6.2.2.1.1.4 NoModeConfigs Mcu\_ModeType NoModeConfigs

Total number of MCU modes.

Definition at line 184 of file Mcu.h.

## $6.2.2.1.1.5 \quad NoClkConfigs \quad \texttt{Mcu\_ClockType NoClkConfigs}$

Total number of MCU clock configurations.

Definition at line 188 of file Mcu.h.

## 6.2.2.1.1.6 RamConfigArrayPtr const Mcu\_RamConfigType(\* RamConfigArrayPtr)[((uint32) 1U)]

RAM data configuration.

Definition at line 192 of file Mcu.h.

# $\textbf{6.2.2.1.1.7} \quad Mode ConfigArrayPtr \quad \texttt{const} \quad \texttt{Mcu\_ModeConfigType} \ (* \ \texttt{ModeConfigArrayPtr}) \ [ \ ( \ \texttt{(uint32)} \quad \texttt{6U)} \ ]$

Power Modes data configuration.

Clock data configuration.

Definition at line 196 of file Mcu.h.

# $6.2.2.1.1.8 \quad HwIPsConfigPtr \quad \texttt{const} \; \; \texttt{Mcu\_HwIPsConfigType*} \; \; \texttt{HwIPsConfigPtr}$

IPs data generic configuration.

Definition at line 203 of file Mcu.h.

# 6.2.3 Macro Definition Documentation

# 6.2.3.1 MCU\_VENDOR\_ID

#define MCU\_VENDOR\_ID

Import all data types from lower layers that should be exported. Mcu.h shall include Mcu\_Cfg.h for the API pre-compiler switches.

Definition at line 63 of file Mcu.h.

# 6.2.4 Types Reference

## 6.2.4.1 Mcu\_HwIPsConfigType

typedef Power\_Ip\_HwIPsConfigType Mcu\_HwIPsConfigType

Mcu driver configuration structure.

Configuration for SIU reset configuration module. Configuration for power management and SSCM. Configuration for FLASH controller. Used by "Mcu ConfigType" structure.

Definition at line 193 of file Mcu\_Ipw\_Types.h.

## 6.2.4.2 Mcu\_ClockConfigType

typedef Clock\_Ip\_ClockConfigType Mcu\_ClockConfigType

Definition of a Clock configuration.

This configuration is transmitted as parameter to Mcu\_Ipw\_InitClock() API. Used by "Mcu\_ConfigType" structure.

Note

The structure Mcu\_ConfigType shall provide a configurable (enable/ disable) clock failure notification if the MCU provides an interrupt for such detection.

Definition at line 206 of file Mcu\_Ipw\_Types.h.

### 6.2.4.3 Mcu\_RamConfigType

typedef Ram\_Ip\_RamConfigType Mcu\_RamConfigType

Definition of a Clock configuration.

This configuration is transmitted as parameter to Mcu\_Ipw\_InitClock() API. Used by "Mcu\_ConfigType" structure.

Note

The structure Mcu\_ConfigType shall provide a configurable (enable/ disable) clock failure notification if the MCU provides an interrupt for such detection.

Definition at line 220 of file Mcu\_Ipw\_Types.h.

## 6.2.4.4 Mcu\_ModeConfigType

typedef Power\_Ip\_ModeConfigType Mcu\_ModeConfigType

Definition of a Mode configuration.

This configuration is transmitted as parameter to Mcu\_Ipw\_SetMode() API. Used by "Mcu\_ConfigType" structure.

Definition at line 230 of file Mcu Ipw Types.h.

## 6.2.5 Enum Reference

### 6.2.5.1 Mcu\_ClockNotificationType

 $\verb"enum Mcu_ClockNotificationType"$ 

 $Mcu\_ClockNotificationType.$ 

Clock failure notification. Enable/disable clock failure interrupt generated by the MCU.

Enumerator

| MCU_CLK_NOTIF_DIS | Disable clock notification. |
|-------------------|-----------------------------|
| MCU_CLK_NOTIF_EN  | Enable clock notification.  |

Definition at line 172 of file Mcu\_Ipw\_Types.h.

## 6.2.6 Function Reference

# 6.2.6.1 Mcu\_Init()

MCU driver initialization function.

This routine initializes the MCU Driver. The intention of this function is to make the configuration setting for power down, clock and Ram sections visible within the MCU Driver.

#### Parameters

| in | ConfigPtr | Pointer to configuration structure. |
|----|-----------|-------------------------------------|
|----|-----------|-------------------------------------|

#### Returns

void

# 6.2.6.2 Mcu\_InitRamSection()

```
\begin{tabular}{lll} Std\_ReturnType & Mcu\_InitRamSection & \\ & Mcu\_RamSectionType & RamSection & \\ \end{tabular}
```

MCU driver initialization of Ram sections.

Function initializes the ram section selected by RamSection parameter. The section base address, size and value to be written are provided from the configuration structure. The function will write the value specified in the configuration structure indexed by RamSection. After the write it will read back the RAM to verify that the requested value was written.

#### Parameters

|  | in | RamSection | Index of ram section from configuration structure to be initialized. |
|--|----|------------|----------------------------------------------------------------------|
|--|----|------------|----------------------------------------------------------------------|

### Returns

Command has or has not been accepted.

### Return values

| $E\_OK$      | Valid parameter, the driver state allowed execution and the RAM check was successful              |
|--------------|---------------------------------------------------------------------------------------------------|
| $E\_NOT\_OK$ | Invalid parameter, the driver state did not allowed execution or the RAM check was not successful |

# 6.2.6.3 Mcu\_InitClock()

MCU driver clock initialization function.

This function intializes the PLL and MCU specific clock options. The clock setting is provided from the configuration structure.

#### Parameters

#### Returns

Command has or has not been accepted.

## Return values

| E_OK         | The driver state allowed the execution of the function and the provided parameter was in range |  |
|--------------|------------------------------------------------------------------------------------------------|--|
| $E\_NOT\_OK$ | The driver state did not allowed execution or the parameter was invalid                        |  |

## 6.2.6.4 Mcu\_SetMode()

This function sets the MCU power mode.

This function activates MCU power mode from config structure selected by McuMode parameter. If the driver state is invalid or McuMode is not in range the function will skip changing the mcu mode.

### Parameters

| in Mcv | Mode   MCU mode setting ID from config structure to | be set. |
|--------|-----------------------------------------------------|---------|
|--------|-----------------------------------------------------|---------|

### Returns

void

### 6.2.6.5 Mcu\_DistributePllClock()

This function activates the PLL clock to the MCU clock distribution.

Function completes the PLL configuration and then activates the PLL clock to MCU. If the MCU\_NO\_PLL is TRUE the Mcu\_DistributePllClock has to be disabled. The function will not distribute the PLL clock if the driver state does not allow it, or the PLL is not stable.

Returns

Std\_ReturnType

#### Return values

| $E\_OK$  | Command has been accepted.     |
|----------|--------------------------------|
| E_NOT_OK | Command has not been accepted. |

## 6.2.6.6 Mcu\_GetPllStatus()

This function returns the lock status of the PLL.

The user takes care that the PLL is locked by executing Mcu\_GetPllStatus. If the MCU\_NO\_PLL is TRUE the MCU\_GetPllStatus has to return MCU\_PLL\_STATUS\_UNDEFINED. It will also return MCU\_PLL\_STATU  $\leftarrow$  S\_UNDEFINED if the driver state was invalid

Returns

Mcu\_PllStatusType Provides the lock status of the PLL.

### Return values

| MCU_PLL_STATUS_UNDEFINED | PLL Status is unknown. |
|--------------------------|------------------------|
| $MCU\_PLL\_LOCKED$       | PLL is locked.         |
| $MCU\_PLL\_UNLOCKED$     | PLL is unlocked.       |

### 6.2.6.7 Mcu\_GetResetReason()

This function returns the Reset reason.

This routine returns the Reset reason that is read from the hardware.

Returns

Mcu\_ResetType Reason of the Reset event.

## 6.2.6.8 Mcu\_GetResetRawValue()

This function returns the Raw Reset value.

This routine returns the Raw Reset value that is read from the hardware.

Returns

Mcu\_RawResetType Description of the returned value.

Return values

uint32 | Code of the Raw reset value.

### 6.2.6.9 Mcu\_PerformReset()

This function performs a microcontroller reset.

This function performs a microcontroller reset by using the hardware feature of the microcontroller. In case the function returns, the user must reset the platform using an alternate reset mechanism

Returns

void

### 6.2.6.10 Mcu\_GetVersionInfo()

This function returns the Version Information for the MCU module.

This function returns the vendor id, module id, major, minor and patch version.

#### Parameters

#### Returns

void

# 6.2.6.11 Mcu\_GetPowerModeState()

This function returns the System Status (power mode, clock settings) from MC\_ME hw IP. The return value is the content register read from hardware (ME\_GS). The return value shall evidentiate the current running mode, clock settings and activation, etc.

Returns

Mcu\_PowerModeStateType Get the state of the power mode.

## Return values

```
uint32 | Content of ME_GS register.
```

## 6.2.6.12 Mcu\_DisableCmu()

Disable clock monitoring unit.

This function disables the selected clock monitoring unit.

### Precondition

Function requires an execution of Mcu\_Init() before it can be used.

## Parameters

Returns

void

# 6.2.6.13 Mcu\_GetClockFrequency()

Return the frequency of a given clock.

This function returns the frequency of a given clock which is request by user.

#### Precondition

Function requires an execution of Mcu\_Init() before it can be used,

#### Parameters

| in | ClockName | Name of the monitor clock for which CMU must be disabled. |
|----|-----------|-----------------------------------------------------------|
|----|-----------|-----------------------------------------------------------|

Returns

uint32

## 6.2.6.14 Mcu\_SleepOnExit()

This function disable/enable SleepOnExit.

Disable/enable Sleep on exit when returning from Handler mode to Thread mode.

### Parameters

| in | Mcu_SleepOnExitType | The value will be configured to SLEEPONEXIT bits.     |  |
|----|---------------------|-------------------------------------------------------|--|
|    |                     | MCU_SLEEP_ON_EXIT_DISABLED - Disable SLEEPONEXIT bit. |  |
|    |                     | MCU_SLEEP_ON_EXIT_ENABLED - Enable SLEEPONEXIT bit.   |  |

Returns

void

## 6.2.6.15 Mcu\_PmcAeConfig()

```
void Mcu_PmcAeConfig (
     void )
```

This function configure the Power Management Controller AE. This function configure the Power Management Controller AE of the microcontroller.

Returns

void

## 6.2.6.16 Mcu\_AecResetConfig()

This function configure the Reset config AEC. This function configure the Reset config AEC of the microcontroller.

Returns

void

# 6.2.6.17 Mcu\_ReportDemTimeoutError()

Reports timeout error to DEM.

Checks if the timeout expired and reports the timeout error to DEM if that is the case.

### Parameters

Returns

void.

# 6.2.6.18 Mcu\_ReportDemSwitchModeError()

Reports failed switch mode to DEM.

Directly reports the clock multiplexer switch error to DEM.

## Parameters



Returns

void.

# 6.2.6.19 Mcu\_Ipw\_SRAMRetentionConfig()

Configuration for SRAM retention.

This function configure for both SRAML\_RETEN and SRAMU\_RETEN bits.

Returns

void

# 6.3 Power Ip Driver

## 6.3.1 Detailed Description

### **Data Structures**

- struct Power\_Ip\_AEC\_ConfigType

  Configuration for AEC. More...
- struct Power\_Ip\_PMC\_ConfigType Configuration for PMC. More...
- struct Power\_Ip\_RCM\_ConfigType RCM IP configuration. More...
- struct Power\_Ip\_SMC\_ConfigType

  SMC IP configuration. More...
- $\bullet \ \ struct \ Power\_Ip\_HwIPsConfigType$

More...

• struct Power\_Ip\_ModeConfigType

Definition of a MCU mode section in the configuration structure. More...

# Types Reference

- $\bullet \ \ typedef \ uint 32 \ Power\_Ip\_ModeType$ 
  - The Power\_Ip\_ModeType specifies the identification (ID) for a MCU mode, configured via configuration structure.
- typedef uint32 Power\_Ip\_RawResetType
  - $The \ type \ \textit{Mcu}\_\textit{RawResetType specifies the reset reason in raw \ register format, \ read \ from \ a \ reset \ status \ register.}$
- typedef void(\* Power\_Ip\_ReportErrorsCallbackType) (Power\_Ip\_ReportErrorType Error, uint8 ErrorCode)

  \*Power report error callback structure. Implements PowerReportErrorCallbackType\_Class.

## Enum Reference

- enum Power\_Ip\_PMC\_StatusType
- enum Power\_Ip\_PowerModeType

Power Modes encoding.

• enum Power\_Ip\_ReportErrorType

Power ip report error types.

# **Function Reference**

- void Power\_Ip\_Init (const Power\_Ip\_HwIPsConfigType \*HwIPsConfigPtr)

  Power initialization.
- void Power\_Ip\_SetMode (const Power\_Ip\_ModeConfigType \*ModeConfigPtr) Sets mode.
- $\bullet \ \ void \ Power\_Ip\_PerformReset \ (const \ Power\_Ip\_HwIPsConfigType \ *HwIPsConfigPtr) \\ Performs \ reset.$
- $\bullet \ \ Power\_Ip\_ResetType\ Power\_Ip\_GetResetReason\ (void)$
- Power\_Ip\_RawResetType Power\_Ip\_GetResetRawValue (void)

Returns raw reset type.

Returns reset type.

- void Power\_Ip\_InstallNotificationsCallback (Power\_Ip\_ReportErrorsCallbackType ReportErrorsCallback)
   Install report error callback.
- void Power Ip CM4 SystemReset (void)

The function initiates a system reset request to reset the SoC.

• void Power\_Ip\_StartTimeout (uint32 \*StartTimeOut, uint32 \*ElapsedTimeOut, uint32 \*TimeoutTicksOut, uint32 TimeoutUs)

Initializes a starting reference point for timeout.

• boolean Power\_Ip\_TimeoutExpired (uint32 \*StartTimeInOut, uint32 \*ElapsedTimeInOut, uint32 Timeout← Ticks)

Checks for timeout condition.

### 6.3.2 Data Structure Documentation

### 6.3.2.1 struct Power\_Ip\_AEC\_ConfigType

Configuration for AEC.

The Reset generator configuration (AEC\_RSTGEN\_CFG)

Definition at line 136 of file Power\_Ip\_AEC\_Types.h.

Data Fields

| Type   | Name      | Description                                     |  |
|--------|-----------|-------------------------------------------------|--|
| uint16 | Rstgencfg | Reset generator configuration (AEC_RSTGEN_CFG). |  |

# 6.3.2.2 struct Power\_Ip\_PMC\_ConfigType

Configuration for PMC.

The power control unit (PMC) acts as a bridge for mapping the PMC peripheral to the PMC address space.

Definition at line 232 of file Power Ip PMC Types.h.

## Data Fields

| Type   | Name         | Description                         |  |
|--------|--------------|-------------------------------------|--|
| uint8  | Lvdsc2       | Trimming Register (PMC_LVDSC2).     |  |
| uint8  | Regsc        | Trimming Register (PMC_REGSC).      |  |
| uint32 | PmcAeConfig  | Trimming Register (PMC_AE_CONFIG).  |  |
| uint32 | PmcAeMonitor | Trimming Register (PMC_AE_MONITOR). |  |

# 6.3.2.3 struct Power\_Ip\_RCM\_ConfigType

RCM IP configuration.

This structure contains information for peripheral configuration

Definition at line 211 of file Power\_Ip\_RCM\_Types.h.

# ${\bf 6.3.2.4 \quad struct \ Power\_Ip\_SMC\_ConfigType}$

SMC IP configuration.

This structure contains information for allowed modes

Definition at line 176 of file Power\_Ip\_SMC\_Types.h.

# ${\bf 6.3.2.5}\quad {\bf struct\ Power\_Ip\_HwIPsConfigType}$

Definition at line 217 of file Power\_Ip\_Types.h.

## Data Fields

| Туре                            | Name         | Description                                                             |
|---------------------------------|--------------|-------------------------------------------------------------------------|
| const Power_Ip_RCM_ConfigType * | RCMConfigPtr | Configuration for RCM (Reset Generation Module) hardware IP.            |
| const Power_Ip_PMC_ConfigType * | PMCConfigPtr | Configuration for PMC (Power Management Unit) hardware IP, part of PMC. |
| const Power_Ip_SMC_ConfigType * | SMCConfigPtr | Configuration for SMC hardware IP.                                      |
| const Power_Ip_AEC_ConfigType * | AECConfigPtr | Configuration for AEC hardware IP.                                      |

## 6.3.2.6 struct Power\_Ip\_ModeConfigType

Definition of a MCU mode section in the configuration structure.

Specifies the system behaviour during the selected target mode. Data set and configured by Mcu\_SetMode call.

Definition at line 251 of file Power\_Ip\_Types.h.

Data Fields

| Type                             | Name        | Description                            |
|----------------------------------|-------------|----------------------------------------|
| Power_Ip_ModeType   ModeConfigId |             | The ID for Power Mode configuration.   |
| Power_Ip_PowerModeType           | PowerMode   | Power modes control configuration.     |
| uint8                            | SleepOnExit | Indicates sleep-on-exit configuration. |

# 6.3.3 Types Reference

## 6.3.3.1 Power\_Ip\_ModeType

typedef uint32 Power\_Ip\_ModeType

The Power\_Ip\_ModeType specifies the identification (ID) for a MCU mode, configured via configuration structure.

The type shall be uint8, uint16 or uint32.

Definition at line 211 of file Power\_Ip\_Types.h.

# ${\bf 6.3.3.2}\quad {\bf Power\_Ip\_RawResetType}$

typedef uint32 Power\_Ip\_RawResetType

The type Mcu\_RawResetType specifies the reset reason in raw register format, read from a reset status register.

The type shall be uint8, uint16 or uint32 based on best performance.

Destructive and Functional Reset Events Log.

Definition at line 268 of file Power\_Ip\_Types.h.

# ${\bf 6.3.3.3}\quad {\bf Power\_Ip\_ReportErrorsCallbackType}$

typedef void(\* Power\_Ip\_ReportErrorsCallbackType) (Power\_Ip\_ReportErrorType Error, uint8 ErrorCode)

 $Power\ report\ error\ callback\ structure.\ Implements\ PowerReportErrorCallback\ Type\_Class.$ 

Definition at line 289 of file Power\_Ip\_Types.h.

# 6.3.4 Enum Reference

# ${\bf 6.3.4.1 \quad Power\_Ip\_PMC\_StatusType}$

enum Power\_Ip\_PMC\_StatusType

### Enumerator

| PMC_UNINIT | The PMC driver is uninitialized. |
|------------|----------------------------------|
| PMC_INIT   | The PMC driver is initialized.   |

Definition at line 247 of file Power\_Ip\_PMC\_Types.h.

# ${\bf 6.3.4.2}\quad {\bf Power\_Ip\_PowerModeType}$

enum Power\_Ip\_PowerModeType

Power Modes encoding.

Supported power modes for SMC hw IP.

## Enumerator

| POWER_IP_RUN_MODE   | Run Mode.                 |
|---------------------|---------------------------|
| POWER_IP_HSRUN_MODE | High Speed Mode.          |
| POWER_IP_VLPR_MODE  | Very Low Power Run Mode.  |
| POWER_IP_VLPS_MODE  | Very Low Power Stop Mode. |
| POWER_IP_STOP1_MODE | Stop 1 Mode.              |
| POWER_IP_STOP2_MODE | Stop 2 Mode.              |

Definition at line 236 of file Power\_Ip\_Types.h.

# 6.3.4.3 Power\_Ip\_ReportErrorType

enum Power\_Ip\_ReportErrorType

Power ip report error types.

## Enumerator

| POWER_IP_REPORT_TIMEOUT_ERROR      | Report Timeout Error.                        |
|------------------------------------|----------------------------------------------|
| POWER_IP_ISR_ERROR                 | Notification Error.                          |
| POWER_IP_PMC_ERROR                 | Notification PMC.                            |
|                                    | Report switch mode Error.                    |
| POWER_IP_REPORT_SWITCH_MODE_ERROR  |                                              |
| POWER_IP_REPORT_VLPSA_NOTIFICATION | Report the VLPS transition was aborted.      |
| POWER_IP_ISR_VOLTAGE_HVD_VDDINT_   | Report the Voltage on VDDINT is high-voltage |
| DETECT                             | detected.                                    |

### Enumerator

|                                    | Report the Voltage on VDD15 is high-voltage         |
|------------------------------------|-----------------------------------------------------|
| POWER_IP_ISR_VOLTAGE_HVD_15_DETECT | detected.                                           |
| POWER_IP_ISR_VOLTAGE_HVD_VDD_DE↔   | Report the Voltage on VDD is high-voltage detected. |
| TECT                               |                                                     |
| POWER_IP_ISR_VOLTAGE_LVD_VDDC_DE↔  | Report the Voltage on VDDC is low-voltage detected. |
| TECT                               |                                                     |
| DOLLED ID 10D HOLELOG LUD HIG DEE  |                                                     |
| POWER_IP_ISR_VOLTAGE_LVD_VLS_DET←  | Report the Voltage on VLS is low-voltage detected.  |

Definition at line 271 of file Power\_Ip\_Types.h.

# 6.3.5 Function Reference

# 6.3.5.1 Power\_Ip\_Init()

Power initialization.

This function power initialization

Parameters

| in   HwIPsConfigPtr   power initialization configuration | n. |
|----------------------------------------------------------|----|
|----------------------------------------------------------|----|

Returns

void

# 6.3.5.2 Power\_Ip\_SetMode()

Sets mode.

This function sets mode.

#### Parameters

| in $ModeConfigPtr$ | power set mote configuration. |
|--------------------|-------------------------------|
|--------------------|-------------------------------|

Returns

void

# 6.3.5.3 Power\_Ip\_PerformReset()

Performs reset.

This function performs reset.

Parameters

| in $HwIPs$ | ConfigPtr | reset initialization configuration. |
|------------|-----------|-------------------------------------|
|------------|-----------|-------------------------------------|

Returns

void

## 6.3.5.4 Power\_Ip\_GetResetReason()

Returns reset type.

This function returns reset type.

Returns

 $Power\_Ip\_ResetType\ Reset\ type$ 

# 6.3.5.5 Power\_Ip\_GetResetRawValue()

Returns raw reset type.

This function returns raw reset type.

Returns

Power\_Ip\_RawResetType Raw reset type

# $6.3.5.6 \quad Power\_Ip\_InstallNotificationsCallback()$

Install report error callback.

This function installs a callback for reporting errors from power driver

Parameters

| in ReportErrorsCallback | Callback to be installed. |
|-------------------------|---------------------------|
|-------------------------|---------------------------|

Returns

void

# $\bf 6.3.5.7 \quad Power\_Ip\_CM4\_SystemReset()$

The function initiates a system reset request to reset the SoC.

The function initiates a system reset request to reset the SoC

| in | none |  |
|----|------|--|

### Returns

void

# 6.3.5.8 Power\_Ip\_StartTimeout()

Initializes a starting reference point for timeout.

## Parameters

| out | StartTimeOut    | The starting time from which elapsed time is measured                |
|-----|-----------------|----------------------------------------------------------------------|
| out | ElapsedTimeOut  | The elapsed time to be passed to Power_Ip_TimeoutExpired             |
| out | TimeoutTicksOut | The timeout value (in ticks) to be passed to Power_Ip_TimeoutExpired |
| in  | Timeout Us      | The timeout value (in microseconds)                                  |

# 6.3.5.9 Power\_Ip\_TimeoutExpired()

Checks for timeout condition.

| in,out | StartTimeInOut      | The starting time from which elapsed time is measured         |
|--------|---------------------|---------------------------------------------------------------|
| in,out | Elapsed Time In Out | The accumulated elapsed time from the starting time reference |
| in     | TimeoutTicks        | The timeout limit (in ticks)                                  |

# 6.4 Ram Ip Driver

# 6.4.1 Detailed Description

### **Data Structures**

• struct Ram\_Ip\_RamConfigType

Definition of a RAM section within the configuration structure. The definitions for each RAM section within the structure Ram\_Ip\_ConfigType shall contain: More...

# Types Reference

• typedef uint32 Ram\_Ip\_RamSectionType

The Ram\_Ip\_RamSectionType specifies the identification (ID) for a RAM section, configured via the configuration structure. The type shall be uint8, uint16 or uint32, based on best performance.

• typedef uint32 Ram\_Ip\_RamIndexType

The Ram\_Ip\_RamIndexType specifies the variable for indexing RAM sections. The type shall be uint8, uint16 or uint32, based on best performance.

• typedef Ram\_Ip\_uintPtrType Ram\_Ip\_RamSizeType

 $The \ Ram\_Ip\_RamSizeType \ specifies \ the \ RAM \ section \ size. \ The \ type \ shall \ be \ uint8, \ uint16 \ or \ uint32, \ based \ on \ best \ performance.$ 

• typedef uint32 Ram\_Ip\_RamWriteSizeType

The Ram\_Ip\_RamWriteSizeType specifies the RAM section write size. The type shall be uint8, uint16 or uint32, based on best performance.

### Enum Reference

 $\bullet \ \ enum \ Ram\_Ip\_StatusType$ 

Ram ip status return codes.

### Function Reference

• Ram\_Ip\_StatusType Ram\_Ip\_InitRamSection (const Ram\_Ip\_RamConfigType \*RamConfigPtr)

Initializes RAM section.

### 6.4.2 Data Structure Documentation

### 6.4.2.1 struct Ram\_Ip\_RamConfigType

Definition of a RAM section within the configuration structure. The definitions for each RAM section within the structure Ram\_Ip\_ConfigType shall contain:

- RAM section base address
- Section size
- Data pre-setting to be initialized
- RAM write size

Definition at line 171 of file Ram Ip Types.h.

#### Data Fields

| Type                    | Name                | Description                           |
|-------------------------|---------------------|---------------------------------------|
| Ram_Ip_RamSectionType   | RamSectorId         | The ID for Ram Sector configuration.  |
| uint8(*                 | RamBaseAddrPtr)[1U] | RAM section base address.             |
| Ram_Ip_RamSizeType *    | RamSize             | RAM section size.                     |
| uint64                  | RamDefaultValue     | RAM default value for initialization. |
| Ram_Ip_RamWriteSizeType | RamWriteSize        | RAM section write size.               |

# 6.4.3 Types Reference

## ${\bf 6.4.3.1} \quad {\bf Ram\_Ip\_RamSectionType}$

typedef uint32 Ram\_Ip\_RamSectionType

The Ram\_Ip\_RamSectionType specifies the identification (ID) for a RAM section, configured via the configuration structure. The type shall be uint8, uint16 or uint32, based on best performance.

Definition at line 127 of file Ram\_Ip\_Types.h.

## 6.4.3.2 Ram\_Ip\_RamIndexType

typedef uint32 Ram\_Ip\_RamIndexType

The Ram\_Ip\_RamIndexType specifies the variable for indexing RAM sections. The type shall be uint8, uint16 or uint32, based on best performance.

Definition at line 134 of file Ram\_Ip\_Types.h.

# ${\bf 6.4.3.3} \quad {\bf Ram\_Ip\_RamSizeType}$

typedef Ram\_Ip\_uintPtrType Ram\_Ip\_RamSizeType

The Ram\_Ip\_RamSizeType specifies the RAM section size. The type shall be uint8, uint16 or uint32, based on best performance.

Definition at line 141 of file Ram\_Ip\_Types.h.

# 6.4.3.4 Ram\_Ip\_RamWriteSizeType

```
typedef uint32 Ram_Ip_RamWriteSizeType
```

The Ram\_Ip\_RamWriteSizeType specifies the RAM section write size. The type shall be uint8, uint16 or uint32, based on best performance.

Definition at line 148 of file Ram\_Ip\_Types.h.

# 6.4.4 Enum Reference

## 6.4.4.1 Ram\_Ip\_StatusType

```
enum Ram_Ip_StatusType
```

Ram ip status return codes.

This is the Ram State data type returned by the function Mcu\_GetRamState() of the Mcu module.

#### Enumerator

| RAM_IP_STATUS_OK        | RAM_IP Ok status         |
|-------------------------|--------------------------|
| RAM_IP_STATUS_NOT_OK    | RAM_IP Not ok status     |
| RAM_IP_STATUS_UNDEFINED | RAM_IP Status is unknown |

Definition at line 154 of file Ram\_Ip\_Types.h.

## 6.4.5 Function Reference

## 6.4.5.1 Ram\_Ip\_InitRamSection()

Initializes RAM section.

This function initializes RAM section.

| in | Ram ConfigPtr | Ram section configuration. |
|----|---------------|----------------------------|
|----|---------------|----------------------------|

Returns

 $Ram\_Ip\_StatusType\ Ram\ status$ 

How to Reach Us:

Home Page:

nxp.com

Web Support:

nxp.com/support

Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.com/SalesTermsandConditions.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EMBRACE, GREENCHIP, HITAG, I2C BUS, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, C-5, CodeTEST, CodeWarrior, ColdFire, ColdFire+, C-Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorlQ, QorlQ Qonverge, Ready Play, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, SMARTMOS, Tower, TurboLink, and UMEMS are trademarks of NXP B.V. All other product or service names are the property of their respective owners. ARM, AMBA, ARM Powered, Artisan, Cortex, Jazelle, Keil, SecurCore, Thumb, TrustZone, and Vision are registered trademarks of ARM Limited (or its subsidiaries) in the EU and/or elsewhere. ARM7, ARM9, ARM11, big.LITTLE, CoreLink, CoreSight, DesignStart, Mali, mbed, NEON, POP, Sensinode, Socrates, ULINK and Versatile are trademarks of ARM Limited (or its subsidiaries) in the EU and/or elsewhere. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

© 2023 NXP B.V.

